变音符问题,从数据库java获取数据

问题描述 投票:1回答:1

我有MySQL数据库,我保存了数据,有些词有变音符号。

这是我的功能如何从数据库中获取数据。

public List<RowType> getData(String query){

    List<RowType> list = new ArrayList<>();
    try{
        connect();
        Statement statement = connection.createStatement();
        ResultSet resultSet = statement.executeQuery(query);

        while(resultSet.next()){
            StringBuilder str = new StringBuilder();
            for(int i = 1; i <= getCountColumns(resultSet); i++){
                if(i==1) str.append(resultSet.getString(i));
                else str.append("," + resultSet.getString(i));
            }
            list.add(new RowType(str.toString()));
        }
    }
    catch(Exception e){
        System.out.println("Chyba při získavání údajů z databáze.");
        System.out.println(e);
        Console.print("Chyba při získavání údajů z databáze.");
        Console.print(e.toString());
    }
    finally{
        disconnect();
    }
    return list;
}

作为参数我发送此查询。

List<RowType> list = connection.getData("Select id from countries where name = 'Česko'");

但它找不到任何东西,因为我在查询中有变音符号(“Česko”)。我尝试没有变音符号,它的工作原理。所以,你不知道如何解决它与口音一起工作?

java mysql database string diacritics
1个回答
0
投票

在执行主查询之前,您可以尝试添加一些查询吗?所以它看起来像:

connect();
Statement statement = connection.createStatement();

String query2 = "SET NAMES 'utf8'";
statement.execute(query2);

query2 = "SET CHARACTER SET 'utf8'";
statement.execute(query2);

ResultSet resultSet = statement.executeQuery(query);

如果以上内容对您不起作用,那么您的数据库设置可能存在问题;如果是这种情况,你可以参考答案here

© www.soinside.com 2019 - 2024. All rights reserved.