首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >发音符号的问题,从数据库java获取数据

发音符号的问题,从数据库java获取数据
EN

Stack Overflow用户
提问于 2019-03-12 06:44:05
回答 1查看 154关注 0票数 1

我有MySQL数据库,我在那里保存了数据,一些单词有变音符号。

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

代码语言:javascript
复制
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;
}

作为参数,我发送这个查询。

代码语言:javascript
复制
List<RowType> list = connection.getData("Select id from countries where name = 'Česko'");

但是它找不到任何东西,因为我在查询中有变音符号("Česko")。我试着不加变音符号,它很管用。那么,你不知道如何修复它与口音的工作吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-12 10:11:08

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

代码语言:javascript
复制
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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55111501

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档