Clob,Blob,InputStream,byte 互转
2019独角兽企业重金招聘Python工程师标准>>>
今天用java读取oracle里的Clob字段。本来要转成xml文件的,一顿转换。现在总结一下这个流的互相转换方法。
以下内容来自:http://hi.baidu.com/webidea/item/8965fd99de1034dd1e4271e1
一、byte[]=>Blob
我们可以通过Hibernate提供的表态方法来实现如:
org.hibernate.Hibernate.Hibernate.createBlob(new byte[1024]);
二、Blob=>byte[]
/**
* 把Blob类型转换为byte数组类型
* @param blob
* @return
*/
private byte[] blobToBytes(Blob blob) {BufferedInputStream is = null;try {is = new BufferedInputStream(blob.getBinaryStream());byte[] bytes = new byte[(int) blob.length()];int len = bytes.length;int offset = 0;int read = 0;while (offset < len && (read = is.read(bytes, offset, len offset)) >= 0) {offset += read;}return bytes;} catch (Exception e) {return null;} finally {try {is.close();is = null;} catch (IOException e) {return null;}}
}
三、InputStream=>byte[]
private byte[] InputStreamToByte(InputStream is) throws IOException { ByteArrayOutputStream bytestream = new ByteArrayOutputStream(); int ch; while ((ch = is.read()) != -1) { bytestream.write(ch); } byte imgdata[] = bytestream.toByteArray(); bytestream.close(); return imgdata;
}
四、byte[] => InputStream
byte[]到inputStream之间的转换很简单:
InputStream is = new ByteArrayInputStream(new byte[1024]);
五、InputStream => Blob
可通过Hibernate提供的API:
Hibernate.createBlob(new FileInputStream(" 可以为图片/文件等路径 "));
六、Blob => InputStream
Blog转流,可通过提供的API直接调用:
new Blob().getBinaryStream();
=================
以下内容为原创
Clob转InputStream
InputStream fileOs=null;
Clob clob= res.getClob("XXXX");
int i=0;
fileOs = clob.getAsciiStream();
int len = (int)clob.length();
byte by[] = new byte[len];
try {while(-1 != (i = fileOs.read(by, 0, by.length))){fileOs.read(by, 0, i);}
} catch (IOException e) {e.printStackTrace();
}
这里有个很详细的java操作Blob和Clob的文章
http://wdmcln.iteye.com/blog/100066
最后我的程序里的最终解决方案
先把Clob转成String
oracle.sql.CLOB clob = (CLOB) res.getClob("FILE_CONTENT");
String fileOs=clob.stringValue();
然后把String转成StringReader在来初始化saxReader
SAXReader saxReader = new SAXReader();
saxReader.setValidation(false);
saxReader.setEntityResolver(new NoOpEntityResolver());
Document document = saxReader.read(new StringReader(fileOs));
Element sqlMapElement = document.getRootElement();
这里有个绕弯的地方,没有成功,记录一下,避免以后犯类似的错误
oracle.sql.CLOB clob = (CLOB) res.getClob("FILE_CONTENT");
Reader fileOs=clob.characterStreamValue();SAXReader saxReader = new SAXReader();
saxReader.setValidation(false);
saxReader.setEntityResolver(new NoOpEntityResolver());
Document document = saxReader.read(is);
Element sqlMapElement = document.getRootElement();
前后两部分是两个方法体中的,最后在生成documment的时候会报org.dom4j.DocumentException: 关闭的连接 Nested exception: 关闭的连接,没有成功的解析出来
总结一下,oracle中的大字段有Clob和Blob,主要是字符的大字段和二进制的大字段。java中有inputstream和byte,对应着输入流和二进制数组。
转载于:https://my.oschina.net/zimingforever/blog/81691
Clob,Blob,InputStream,byte 互转相关推荐
- html5 文件转byte[],JS 文件base64、File、Blob、ArrayBuffer互转
二进制互转 1. file对象转base64let reader = new FileReader(); reader.readAsDataURL(file[0]) console.log(reade ...
- oracle里面的long,long raw,raw,clob,blob区别
ORACLE LOB类型提供了BFILE.BLOB.CLOB.NCLOB让我们来存储最大尺寸有4G的无结构的数据块(例如:文本.图像.声音和视频等).并且它们右以以高效的.任意的和分段操作的方式存取数 ...
- Clob Blob
二者相同点:都是存储大文件以及超大文件的,例如:大型文本信息,图片,电影等. 二者不同点: clob:主要存储大型文本信息,在MySQL中字段类型通常设置为text,默认大小,通常是字符流 bolb: ...
- 使用JDBC操作基于Oracle的CLOB,BLOB字段类型
转载至程式先锋技术维客[url]www.javabiz.cn[/url] 先来看看两种LOB类型的主要区别: CLOB 表示Character LOB (字符LOB) 它可以存储大量的字符数据. B ...
- 【Java数据库】CLOB BLOB 在数据库中存入/取出大量文本数据、二进制文件(图片)
CLOB(Character Large Object) – 用于存储大量的文本数据 – 大字段有些特殊,不同数据库处理的方式不一样,大字段的操作常常是以流的 方式来处理的.而非一般的字段,一次即可读 ...
- mysql clob blob,如何在MySQL中插入BLOB和CLOB文件?
I want to store images and .docx/.doc, .pptx/.ppt, .pdf files using the front end of my software. I ...
- CLOB/BOLB与String互转
原文地址http://www.oschina.net/code/snippet_135225_5485#8747,仅仅第十一行代码,便可将BLOB类型转化为String类型,简单粗暴,我喜欢 1 St ...
- 大字段 CLOB/BOLB与String互转
String s1="1234abc我是大字段CLOB或BOLB"; String转大字段 //String 转 clob Clob c = new SerialClob(s1.t ...
- Python转Oracle LOBs(CLOB/BLOB) 为String字符串
从数据库直接读取小于1GB的CLOBs and BLOBs的格式作为字符串,这比数据流方式更快. 这里用到了connection.outputtypehandler: def OutputTypeHa ...
- oracle数据按条件清表,ociuldr v2.1 支持CLOB,BLOB数据类型
1.dcba的ociuldr工具 ociuldr这个工具初始是由dcba开发的,用的是v7版的oci函数库 目的是完成导出Oracle中的数据到文本文件这样的功能 这个工具流传的非常广 详细介绍可以参 ...
最新文章
- 能量平衡_巴夏:平衡自己的能量,疗愈自己,疗愈世界
- linux基础(1)-yum源配置
- linux 进sqlplus命令,linux下的sqlplus命令
- xBIM 基础16 IFC的空间层次结构
- django存入mysql数据库_django如何存数据到一个mysql数据表里面
- Android心得8--Internet
- matlab2c使用c++实现matlab函数系列教程-factorial函数
- linux输入法变成乱码,Linux ibus输入法五笔打字的时候出现乱码框框的解决方案
- Docker镜像重命名
- 华硕老毛子(Padavan)——校园网锐捷(Ruijie)认证路由限制解决方案(锐捷(Ruijie)认证+赛尔认证)
- 计算机在英语教学中的运用,计算机在小学英语教学中的应用
- 微信小程序样式大全(一)
- Screenie for Mac(Mac截图工具)
- 最小二乘法概念和代码示例
- 扫荡倾斜摄影单体化难题
- 北大2011年计算机系录取浙江毛,湖州这11位同学被清华北大录取!
- 按照角度进行图片旋转
- 传奇服务器端如何修改称号,图文解说传奇人物称号设置详细步骤
- 爱贝云计费服务端接入
- Spark jar not loaded. Offending class: javax/servlet/Servlet.class
热门文章
- ssh的mysql分页查询_在SSH框架下按条件分页查询
- 去掉重复值php,php多维数组去掉重复值
- python程序设计pdf上海交大_上海交大2011_2012程序设计python期末考试题
- Barh函数--Matplotlib
- error C4703: 使用了可能未初始化的本地指针变量
- Linux系统centos6.7上安装libevent
- 跳石头 vijos1981 NOIP2015 D2T1 二分答案 模拟 贪心
- 找到好东西,可以显示最忙碌的java线程的脚本
- [APUE]进程关系(上)
- PE格式详细讲解5 - 系统篇05|解密系列