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

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

hot3.png

1.问题描述

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

2.问题复现

测试环境:

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

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

static String 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; ResultSet rs = null; PreparedStatement ps = null;    try {        Class.forName(JDBC_DRIVER); con = DriverManager.getConnection(CONNECTION_URL); String insertsql = "insertinto my_first_table values(46, '测试中文字符')"; ps = con.prepareStatement(insertsql); ps.execute(); ps.close(); ps = con.prepareStatement("select* from my_first_table order by id asc"); rs = ps.executeQuery();        while (rs.next()) {            System.out.println(rs.getLong(1) + "\t" +rs.getString(2)); }    } catch (Exception e) {        e.printStackTrace(); } finally { try { // 关闭rs、ps和con rs.close(); ps.close(); con.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }    }}

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

String insertsql = "insert into my_first_table values(44, '测试')";String insertsql = "insert into my_first_table values(45, '测试中文')";String insertsql = "insert into my_first_table values(46, '测试中文字符')";

如下是按测试顺序插入的数据

通过以上操作重现问题。

3.解决方法

修改程序中插入语句,将插入字符串的单引号修改为双引号

String insertsql = "insert into my_first_table values(51, \"测试中文字符\")";
String insertsql = "insert into my_first_table values(52, \"测试中文\")";
String insertsql = "insert into my_first_table values(53, \"测试\")";

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

使用Hue查询显示如下:

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

4.备注

1.使用Cloudera官网最新的JDBC驱动,插入中文字符时也有上述问题

下载地址:

2.通过Impala-shell插入中文字符串正常

[172.31.10.118:21000] > insert into my_first_table values(66,'插入中文字符');Modified 1 row(s), 0 row error(s) in 0.11s[172.31.10.118:21000] > select * from my_first_table where id=66;+----+--------------+| id | name         |+----+--------------+| 66 | 插入中文字符 |+----+--------------+Fetched 1 row(s) in 0.21s[172.31.10.118:21000] >[172.31.10.118:21000] > insert into my_first_table values(77, "测试中文字符");Modified 1 row(s), 0 row error(s) in 0.11s[172.31.10.118:21000] > select * from my_first_table where id=77;+----+--------------+| id | name         |+----+--------------+| 77 | 测试中文字符 |+----+--------------+Fetched 1 row(s) in 0.18s[172.31.10.118:21000] >

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

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

你可能感兴趣的文章
setenv 和 set
查看>>
.sh
查看>>
碱基序列的儿子最长上涨
查看>>
Android UI SurfaceView的使用-绘制组合图型,并使其移动
查看>>
C# 属性、索引
查看>>
(转)Java多线程之Lock的使用 (待整理)
查看>>
Java中Filter、Servlet、Listener的学习
查看>>
Java Code Examples for javax.servlet.http.Part
查看>>
为什么使用模块?
查看>>
【转】让Chrome化身成为摸鱼神器,利用Chorme运行布卡漫画以及其他安卓APK应用教程...
查看>>
细说Debug和Release区别
查看>>
Oracle分页
查看>>
WPF学习拾遗(二)TextBlock换行
查看>>
ADSL自动更换IP地址源代码
查看>>
关于第三方IOS的checkBox框架的使用
查看>>
-bash: /bin/rm: Argument list too long的解决办法
查看>>
7.10 数据注解特性--NotMapped
查看>>
Oracle 12C -- 清空audit记录
查看>>
centos7 install mysql
查看>>
ReferenceQueue的使用
查看>>