博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
0021-使用JDBC向Kudu表插入中文字符-cast的秘密
阅读量:7167 次
发布时间:2019-06-29

本文共 2106 字,大约阅读时间需要 7 分钟。

hot3.png

1.问题描述

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

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

2.问题复现

测试环境:

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

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

staticString JDBC_DRIVER ="com.cloudera.impala.jdbc41.Driver";static String CONNECTION_URL ="jdbc:impala://ip-172-31-10-118:21050/default";public static void main(String[] args) {    Connection con = null; ResultSetrs = null; PreparedStatementps = null;    try {        Class.forName(JDBC_DRIVER); con =DriverManager.getConnection(CONNECTION_URL); Stringsql2 = "insert into my_first_table values(?, ?)"; ps =con.prepareStatement(sql2); ps.setInt(1,81); ps.setString(2,"测试中文字符"); ps.execute(); ps.close(); ps =con.prepareStatement("select * from my_first_table order byid asc"); rs = ps.executeQuery();        while (rs.next()){            System.out.println(rs.getLong(1)+ "\t" +rs.getString(2)); }    } catch (Exceptione) {        e.printStackTrace(); } finally{ try {// 关闭rs、ps和con rs.close(); ps.close(); con.close(); } catch(SQLException e) { // TODOAuto-generated catch block e.printStackTrace(); }    }}

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

String sql2 = "insert into my_first_table values(?, ?)";ps = con.prepareStatement(sql2);ps.setInt(1, 73);ps.setString(2, "测试");ps.execute();ps.close();ps = con.prepareStatement(sql2);ps.setInt(1, 74);ps.setString(2, "测试中文");ps.execute();ps.close();ps = con.prepareStatement(sql2);ps.setInt(1, 75);ps.setString(2, "测试中文字符");ps.execute();ps.close();

通过Hue查询结果如下:

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

3.解决方法

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

String sql2 = "insert into my_first_table values(?, cast(?as string))";ps = con.prepareStatement(sql2);ps.setInt(1, 60);ps.setString(2, "测试中文字符");ps.execute();ps.close();ps = con.prepareStatement(sql2);ps.setInt(1, 61);ps.setString(2, "测试中文");ps.execute();ps.close();ps = con.prepareStatement(sql2);ps.setInt(1, 62);ps.setString(2, "测试");ps.execute();ps.close();

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

使用Hue查询显示如下:

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

醉酒鞭名马,少年多浮夸! 岭南浣溪沙,呕吐酒肆下!挚友不肯放,数据玩的花!

转载于:https://my.oschina.net/u/4016761/blog/2878426

你可能感兴趣的文章
DataTable转List<T>
查看>>
安卓项目开发
查看>>
使用C#把发表的时间改为几个月,几天前,几小时前,几分钟前,或几秒前
查看>>
2019-06-11 Java学习日记之Bootstrap
查看>>
解决apache 443端口被占用
查看>>
PHP中PDO错误/异常(PDOException)处理
查看>>
中国科学院大学生创新实践训练计划-
查看>>
洛谷——P1294 高手去散步
查看>>
python正则表达式
查看>>
Blob写入文件
查看>>
Again Stone Game
查看>>
MySQL 5.7.9修改root密码以及新特性
查看>>
HTML5 —— 属性
查看>>
Oracle Alter Table Modify列语句
查看>>
CentOS7+CDH5.14.0安装全流程记录,图文详解全程实测-3禁止交换和禁用大页面
查看>>
php测试题整理(0519)
查看>>
winform下重画ListBox
查看>>
洛谷 P1439【模板】最长公共子序列
查看>>
String 总结
查看>>
构造函数
查看>>