java string blob_java String与Blob类型数据转换

需要把String类型数据转换成Reader,然后再使用setCharacterStream插入数据库中。

例如下例中,要插入String longStr,则先转换成Byte[],再ByteArrayInputStream,最后InputStreamReader。

添加或更新clob型数据,如下所示(以更新为例):

PreparedStatement   pstmt=conn.prepareStatement(“update   tablename   set   column1=?   “+条件语句);

byte[]     bytes_zyjs     =     longStr.getBytes();

ByteArrayInputStream     baisss     =     new     ByteArrayInputStream(bytes_zyjs);

InputStreamReader     bais     =     new     InputStreamReader(baisss);

pstmt.setCharacterStream(1,bais,bytes_zyjs.length);

pstmt.executeUpdate();

但是如上方式写入汉字就会产生乱码,于是查看资料得知,上述方法多用于oracle下,而mysql下使用的是setBinaryStream方法,只要传入位置,inputstream,和长度即可。示例如下:

byte[] cert_dataBytes = cert_data.getBytes();

ByteArrayInputStream bais1 = new ByteArrayInputStream(cert_dataBytes);

byte[] prikey_dataBytes = prikey_data.getBytes();

ByteArrayInputStream bais2 = new ByteArrayInputStream(prikey_dataBytes);

String sql = "insert into cert_data values(?,?,?)";

PreparedStatement pstm = null;

try {

conn.setAutoCommit(false);

pstm = conn.prepareCall(sql);

pstm.setInt(1,cert_sn);

pstm.setBinaryStream(2, bais1,cert_dataBytes.length);//使用二进制读取,可以直接写入汉字,否则容易产生乱码

pstm.setBinaryStream(3, bais2, prikey_dataBytes.length);

pstm.executeUpdate();

conn.commit();

conn.setAutoCommit(true);

pstm.close();

} catch (SQLException e) {

e.printStackTrace();

}finally{

try {

if(pstm != null)

pstm.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

从数据库中读取Blob类型数据后,要转换成String类型,即转换成InputStream,再从InputStream转成byte[],再到String即可。如下:

//把数据库中blob类型转换成String类型

public String convertBlobToString(Blob blob){

String result = "";

try {

ByteArrayInputStream msgContent =(ByteArrayInputStream) blob.getBinaryStream();

byte[] byte_data = new byte[msgContent.available()];

msgContent.read(byte_data, 0,byte_data.length);

result = new String(byte_data);

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

return result;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值