为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

繁星淼淼 2022-08-03 15:58:08
我有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”)。我尝试没有变音符号,它的工作原理。所以你不知道如何修复它以使用口音吗?
查看完整描述

1 回答

?
吃鸡游戏

TA贡献1829条经验 获得超7个赞

是否可以尝试在执行主查询之前再添加几个查询?所以它看起来像这样:


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);

如果上述方法对您不起作用,则可能是您的数据库设置有问题;如果是这种情况,您可以参考此处的答案


查看完整回答
反对 回复 2022-08-03
  • 1 回答
  • 0 关注
  • 162 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号