1. 程式人生 > >0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

溫馨提示:要看高清無碼套圖,請使用手機開啟並單擊圖片放大檢視。

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, '測試中文字元')";

如下是按測試順序插入的資料

0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

通過以上操作重現問題。

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查詢顯示如下:

0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

中文字串插入Kudu顯示正常。

4.備註

1.使用Cloudera官網最新的JDBC驅動,插入中文字元時也有上述問題

下載地址:https://downloads.cloudera.com/connectors/impala\_jdbc\_2.5.38.1058.zip

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] > 

0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

0020-使用JDBC向Kudu表插入中文字元-雙引號的祕密

醉酒鞭名馬,少年多浮誇! 嶺南浣溪沙,嘔吐酒肆下!摯友不肯放,資料玩的花!

溫馨提示:要看高清無碼套圖,請使用手機開啟並單擊圖片放大檢視。

歡迎關注Hadoop實操,第一時間,分享更多Hadoop乾貨,喜歡請關注分享。

原創文章,歡迎轉載,轉載請註明:轉載自微信公眾號Hadoop實操