Oracle中存储图片的类型为BLOB类型,Java中如何将其读取并转为字符串?

Posted MrQuan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle中存储图片的类型为BLOB类型,Java中如何将其读取并转为字符串?相关的知识,希望对你有一定的参考价值。

一,读取图片转为String类型: 需要使用Sun公司提供的Base64工具

String str = ((Map) list1.get(0)).get("EINVOICEFILE").toString(); //通过查询取出EINVOICEFILE的属性值,EINVOICEFILE在数据库中以(1:cat.png)这种varchar类型存储(公司平台需要可忽略)。


String[] filemap = str.split(":");
String id = filemap[0];  //分割字符串,拿到冒号前面的id,即 1


String sql_qr = "select content from hebfs.pt994 where id =?";
List list2 = DataBaseHelper.queryForList(sql_qr, new Object[] {id });  //content就是存储图片的blob数据,查询出放到list中。

String strBase64 = null;
byte[] bytes = (byte[])(((Map) list2.get(0)).get("CONTENT"));  //这里先从list中取出图片,然后转换成字节数组。

strBase64 = new BASE64Encoder().encode(bytes);  //最后调用base64的encode方法,把字节数组传进去就能得到需要的String数据。
System.out.println(strBase64);

二,如果数据库中的blob字段存储的是XML,读取方法如下:

String sql = " select EINVOICEXML from T_FSEITEMPLATE t where t.id = ? ";
List xml = DataBaseHelper.queryForList(sql, new Object[] { StringUtil.nullToEmpty(p.get("TEMPID"))});  //执行sql,结果存储于List中。


List resultlist = new ArrayList();
for (int i = 0; i <xml.size() ; i++) {     //循环遍历xml集合
Map map = new HashMap();
map = (Map) xml.get(i);
byte[] bytes = (byte[]) map.get("EINVOICEXML");  //把每个值转为字节数组
String s = new String(bytes,"GBk");   //再转为String类型
map.put("EINVOICEXML",s);   //使用Map封装。
resultlist.add(map);   //将封装好的Map存储到list中。
}





















以上是关于Oracle中存储图片的类型为BLOB类型,Java中如何将其读取并转为字符串?的主要内容,如果未能解决你的问题,请参考以下文章

ORACLE数据库BLOB如何转化类型

Oracle中的BLOB和CLOB字段类型的区别

如何在java中读取oracle blob

用JAVA怎样将保存在数据库BLOB类型的图片取出来转换为图片然后在页面展示啊

hibernate课程 初探单表映射3-3 对象类型

关于Oracle中的BLOB字段的问题