0021-使用JDBC向Kudu表插入中文字符-cast的秘密
阿新 • • 發佈:2018-11-20
select tro ack insert println 轉載 cast函數 result 微信公眾
溫馨提示:要看高清無碼套圖,請使用手機打開並單擊圖片放大查看。
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顯示正常。
醉酒鞭名馬,少年多浮誇! 嶺南浣溪沙,嘔吐酒肆下!摯友不肯放,數據玩的花!
溫馨提示:要看高清無碼套圖,請使用手機打開並單擊圖片放大查看。
歡迎關註Hadoop實操,第一時間,分享更多Hadoop幹貨,喜歡請關註分享。
原創文章,歡迎轉載,轉載請註明:轉載自微信公眾號Hadoop實操
0021-使用JDBC向Kudu表插入中文字符-cast的秘密