PreparedStatement 在MySQL下中文亂碼解決方案

來源:互聯網
上載者:User

在頂目中無意中碰到PreparedStatement  在存DB時出現亂碼,困擾了好久終於解決問題

問題代碼如下

  1. pstmt = con.prepareStatement(INSERT_OFFLINE);  
  2.            pstmt.setString(1, username);  
  3.            pstmt.setLong(2, messageID);  
  4.            pstmt.setString(3, StringUtils.dateToMillis(new java.util.Date()));  
  5.            pstmt.setInt(4, msgXML.length());  
  6.            pstmt.setString(5, “中文內容”);  
  7.            pstmt.executeUpdate();  

調試時可以看到在   pstmt.executeUpdate();  行 pstmt  中的 “中文內容” 變成  ????

原因是設定datasource 的driver 時jdbc.url=jdbc:mysql://192.168.12.22:3306/ts 沒有指定編碼

可以按如下修改

jdbc.url=jdbc:mysql://192.168.12.22:3306/ts?characterEncoding=utf8

問題解決

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.