您好,登錄后才能下訂單哦!
溫馨提示:要看高清無碼套圖,請使用手機打開并單擊圖片放大查看。
1.問題描述
使用Impala JDBC向Kudu表中插入中文字符,插入的中文字符串亂碼,中文字符串被截斷。
繼之前文檔使用sql拼接方式插入中文字符串亂碼解決方法后,此文檔描述使用jdbc的PreparedStatement方式插入中文字符串亂碼問題。
2.問題復現(xiàn)
測試環(huán)境:
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 {// 關(guān)閉rs、ps和con
rs.close();
ps.close();
con.close();
} catch(SQLException e) {
// TODOAuto-generated catch block
e.printStackTrace();
}
}
}
2.向Kudu表中分別插入測試數(shù)據(jù),如“測試”,“測試中文”,“測試中文字符”
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查詢結(jié)果如下:
中文字符全部亂碼,部分亂碼,字符串被截斷問題重現(xiàn)。
3.解決方法
修改程序中插入語句,將插入字符串列使用cast函數(shù)轉(zhuǎn)成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中插入測試數(shù)據(jù):“測試中文字符”,“測試中文”,“測試”
使用Hue查詢顯示如下:
中文字符串插入Kudu顯示正常。
醉酒鞭名馬,少年多浮夸! 嶺南浣溪沙,嘔吐酒肆下!摯友不肯放,數(shù)據(jù)玩的花!
溫馨提示:要看高清無碼套圖,請使用手機打開并單擊圖片放大查看。
歡迎關(guān)注Hadoop實操,第一時間,分享更多Hadoop干貨,喜歡請關(guān)注分享。
原創(chuàng)文章,歡迎轉(zhuǎn)載,轉(zhuǎn)載請注明:轉(zhuǎn)載自微信公眾號Hadoop實操
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。