当前位置:Gxlcms > 数据库问题 > 0021-使用JDBC向Kudu表插入中文字符-cast的秘密

0021-使用JDBC向Kudu表插入中文字符-cast的秘密

时间:2021-07-01 10:21:17 帮助过:39人阅读

温馨提示:要看高清无码套图,请使用手机打开并单击图片放大查看。

1.问题描述

使用Impala JDBC向Kudu表中插入中文字符,插入的中文字符串乱码,中文字符串被截断。

继之前文档使用sql拼接方式插入中文字符串乱码解决方法后,此文档描述使用jdbc的PreparedStatement方式插入中文字符串乱码问题。

2.问题复现

测试环境:

  • CDH5.12.0
  • Kudu1.4.0
  • ImpalaJDBC41_2.5.35

1.使用ImpalaJDBC代码进行测试,测试代码

  1. <code> staticString JDBC_DRIVER ="com.cloudera.impala.jdbc41.Driver";
  2. static String CONNECTION_URL ="jdbc:impala://ip-172-31-10-118:21050/default";
  3. public static void main(String[] args) {
  4. Connection con = null;
  5. ResultSetrs = null;
  6. PreparedStatementps = null;
  7. try {
  8. Class.forName(JDBC_DRIVER);
  9. con =DriverManager.getConnection(CONNECTION_URL);
  10. Stringsql2 = "insert into my_first_table values(?, ?)";
  11. ps =con.prepareStatement(sql2);
  12. ps.setInt(1,81);
  13. ps.setString(2,"测试中文字符");
  14. ps.execute();
  15. ps.close();
  16. ps =con.prepareStatement("select * from my_first_table order byid asc");
  17. rs = ps.executeQuery();
  18. while (rs.next()){
  19. System.out.println(rs.getLong(1)+ "\t" +rs.getString(2));
  20. }
  21. } catch (Exceptione) {
  22. e.printStackTrace();
  23. } finally{
  24. try {// 关闭rs、ps和con
  25. rs.close();
  26. ps.close();
  27. con.close();
  28. } catch(SQLException e) {
  29. // TODOAuto-generated catch block
  30. e.printStackTrace();
  31. }
  32. }
  33. }</code>

2.向Kudu表中分别插入测试数据,如“测试”,“测试中文”,“测试中文字符”

  1. <code>String sql2 = "insert into my_first_table values(?, ?)";
  2. ps = con.prepareStatement(sql2);
  3. ps.setInt(1, 73);
  4. ps.setString(2, "测试");
  5. ps.execute();
  6. ps.close();
  7. ps = con.prepareStatement(sql2);
  8. ps.setInt(1, 74);
  9. ps.setString(2, "测试中文");
  10. ps.execute();
  11. ps.close();
  12. ps = con.prepareStatement(sql2);
  13. ps.setInt(1, 75);
  14. ps.setString(2, "测试中文字符");
  15. ps.execute();
  16. ps.close();</code>

通过Hue查询结果如下:

技术分享图片

中文字符全部乱码,部分乱码,字符串被截断问题重现。

3.解决方法

修改程序中插入语句,将插入字符串列使用cast函数转成String类型

  1. <code>String sql2 = "insert into my_first_table values(?, cast(?as string))";
  2. ps = con.prepareStatement(sql2);
  3. ps.setInt(1, 60);
  4. ps.setString(2, "测试中文字符");
  5. ps.execute();
  6. ps.close();
  7. ps = con.prepareStatement(sql2);
  8. ps.setInt(1, 61);
  9. ps.setString(2, "测试中文");
  10. ps.execute();
  11. ps.close();
  12. ps = con.prepareStatement(sql2);
  13. ps.setInt(1, 62);
  14. ps.setString(2, "测试");
  15. ps.execute();
  16. ps.close();</code>

修改后重新向Kudu中插入测试数据:“测试中文字符”,“测试中文”,“测试”

使用Hue查询显示如下:

技术分享图片

中文字符串插入Kudu显示正常。

醉酒鞭名马,少年多浮夸! 岭南浣溪沙,呕吐酒肆下!挚友不肯放,数据玩的花!
温馨提示:要看高清无码套图,请使用手机打开并单击图片放大查看。

欢迎关注Hadoop实操,第一时间,分享更多Hadoop干货,喜欢请关注分享。

技术分享图片

原创文章,欢迎转载,转载请注明:转载自微信公众号Hadoop实操

0021-使用JDBC向Kudu表插入中文字符-cast的秘密

标签:分享   查看   fir   resultset   技术   测试环境   原创文章   exe   system   

人气教程排行