歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Java String與Blob類型數據轉換

Java String與Blob類型數據轉換

日期:2017/3/1 10:07:34   编辑:Linux編程

需要把String類型數據轉換成Reader,然後再使用setCharacterStream插入數據庫中。

例如下例中,要插入String longStr,則先轉換成Byte[],再ByteArrayInputStream,最後InputStreamReader。

添加或更新clob型數據,如下所示(以更新為例):

  1. PreparedStatement pstmt=conn.prepareStatement(“update tablename set column1=? “+條件語句);
  2. byte[] bytes_zyjs = longStr.getBytes();
  3. ByteArrayInputStream baisss = new ByteArrayInputStream(bytes_zyjs);
  4. InputStreamReader bais = new InputStreamReader(baisss);
  5. pstmt.setCharacterStream(1,bais,bytes_zyjs.length);
  6. pstmt.executeUpdate();

但是如上方式寫入漢字就會產生亂碼,於是查看資料得知,上述方法多用於Oracle下,而mysql下使用的是setBinaryStream方法,只要傳入位置,inputstream,和長度即可。示例如下:

  1. byte[] cert_dataBytes = cert_data.getBytes();
  2. ByteArrayInputStream bais1 = new ByteArrayInputStream(cert_dataBytes);
  3. byte[] prikey_dataBytes = prikey_data.getBytes();
  4. ByteArrayInputStream bais2 = new ByteArrayInputStream(prikey_dataBytes);
  5. String sql = "insert into cert_data values(?,?,?)";
  6. PreparedStatement pstm = null;
  7. try {
  8. conn.setAutoCommit(false);
  9. pstm = conn.prepareCall(sql);
  10. pstm.setInt(1,cert_sn);
  11. pstm.setBinaryStream(2, bais1,cert_dataBytes.length);//使用二進制讀取,可以直接寫入漢字,否則容易產生亂碼
  12. pstm.setBinaryStream(3, bais2, prikey_dataBytes.length);
  13. pstm.executeUpdate();
  14. conn.commit();
  15. conn.setAutoCommit(true);
  16. pstm.close();
  17. } catch (SQLException e) {
  18. e.printStackTrace();
  19. }finally{
  20. try {
  21. if(pstm != null)
  22. pstm.close();
  23. } catch (SQLException e) {
  24. e.printStackTrace();
  25. }
  26. }

從數據庫中讀取Blob類型數據後,要轉換成String類型,即轉換成InputStream,再從InputStream轉成byte[],再到String即可。如下:

  1. //把數據庫中blob類型轉換成String類型
  2. public String convertBlobToString(Blob blob){
  3. String result = "";
  4. try {
  5. ByteArrayInputStream msgContent =(ByteArrayInputStream) blob.getBinaryStream();
  6. byte[] byte_data = newbyte[msgContent.available()];
  7. msgContent.read(byte_data, 0,byte_data.length);
  8. result = new String(byte_data);
  9. } catch (SQLException e) {
  10. // TODO Auto-generated catch block
  11. e.printStackTrace();
  12. }
  13. return result;
  14. }
Copyright © Linux教程網 All Rights Reserved