变音符号问题,从数据库中获取数据 java
Problem with diacritic, getting data from database java
我有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”)。我在没有变音符号的情况下尝试了它并且它有效。那么你不知道如何修复它以使其也能与口音一起使用吗?
您可以尝试在执行主查询之前再添加几个查询吗?
所以它看起来像:
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
我有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”)。我在没有变音符号的情况下尝试了它并且它有效。那么你不知道如何修复它以使其也能与口音一起使用吗?
您可以尝试在执行主查询之前再添加几个查询吗? 所以它看起来像:
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