91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-07-20 12:59:14 來源:網絡 閱讀:1426 作者:Hadoop實操 欄目:大數據

溫馨提示:要看高清無碼套圖,請使用手機打開并單擊圖片放大查看。

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查詢結果如下:

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

中文字符全部亂碼,部分亂碼,字符串被截斷問題重現。

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

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

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

醉酒鞭名馬,少年多浮夸! 嶺南浣溪沙,嘔吐酒肆下!摯友不肯放,數據玩的花!
溫馨提示:要看高清無碼套圖,請使用手機打開并單擊圖片放大查看。

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

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

工布江达县| 瓦房店市| 潍坊市| 胶南市| 汉源县| 阜平县| 昌江| 宁陕县| 白水县| 来凤县| 恩施市| 徐水县| 琼结县| 顺昌县| 沙田区| 台州市| 渭南市| 阿城市| 嘉黎县| 无锡市| 翁源县| 治多县| 密山市| 尚志市| 虹口区| 罗山县| 青田县| 康平县| 巨鹿县| 二连浩特市| 华安县| 永安市| 秦皇岛市| 博客| 边坝县| 庐江县| 交城县| 雅江县| 合肥市| 名山县| 永和县|