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 互转相关推荐

  1. html5 文件转byte[],JS 文件base64、File、Blob、ArrayBuffer互转

    二进制互转 1. file对象转base64let reader = new FileReader(); reader.readAsDataURL(file[0]) console.log(reade ...

  2. oracle里面的long,long raw,raw,clob,blob区别

    ORACLE LOB类型提供了BFILE.BLOB.CLOB.NCLOB让我们来存储最大尺寸有4G的无结构的数据块(例如:文本.图像.声音和视频等).并且它们右以以高效的.任意的和分段操作的方式存取数 ...

  3. Clob Blob

    二者相同点:都是存储大文件以及超大文件的,例如:大型文本信息,图片,电影等. 二者不同点: clob:主要存储大型文本信息,在MySQL中字段类型通常设置为text,默认大小,通常是字符流 bolb: ...

  4. 使用JDBC操作基于Oracle的CLOB,BLOB字段类型

    转载至程式先锋技术维客[url]www.javabiz.cn[/url] 先来看看两种LOB类型的主要区别: CLOB 表示Character LOB (字符LOB)  它可以存储大量的字符数据. B ...

  5. 【Java数据库】CLOB BLOB 在数据库中存入/取出大量文本数据、二进制文件(图片)

    CLOB(Character Large Object) – 用于存储大量的文本数据 – 大字段有些特殊,不同数据库处理的方式不一样,大字段的操作常常是以流的 方式来处理的.而非一般的字段,一次即可读 ...

  6. 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 ...

  7. CLOB/BOLB与String互转

    原文地址http://www.oschina.net/code/snippet_135225_5485#8747,仅仅第十一行代码,便可将BLOB类型转化为String类型,简单粗暴,我喜欢 1 St ...

  8. 大字段 CLOB/BOLB与String互转

    String s1="1234abc我是大字段CLOB或BOLB"; String转大字段 //String 转 clob Clob c = new SerialClob(s1.t ...

  9. Python转Oracle LOBs(CLOB/BLOB) 为String字符串

    从数据库直接读取小于1GB的CLOBs and BLOBs的格式作为字符串,这比数据流方式更快. 这里用到了connection.outputtypehandler: def OutputTypeHa ...

  10. oracle数据按条件清表,ociuldr v2.1 支持CLOB,BLOB数据类型

    1.dcba的ociuldr工具 ociuldr这个工具初始是由dcba开发的,用的是v7版的oci函数库 目的是完成导出Oracle中的数据到文本文件这样的功能 这个工具流传的非常广 详细介绍可以参 ...

最新文章

  1. 能量平衡_巴夏:平衡自己的能量,疗愈自己,疗愈世界
  2. linux基础(1)-yum源配置
  3. linux 进sqlplus命令,linux下的sqlplus命令
  4. xBIM 基础16 IFC的空间层次结构
  5. django存入mysql数据库_django如何存数据到一个mysql数据表里面
  6. Android心得8--Internet
  7. matlab2c使用c++实现matlab函数系列教程-factorial函数
  8. linux输入法变成乱码,Linux ibus输入法五笔打字的时候出现乱码框框的解决方案
  9. Docker镜像重命名
  10. 华硕老毛子(Padavan)——校园网锐捷(Ruijie)认证路由限制解决方案(锐捷(Ruijie)认证+赛尔认证)
  11. 计算机在英语教学中的运用,计算机在小学英语教学中的应用
  12. 微信小程序样式大全(一)
  13. Screenie for Mac(Mac截图工具)
  14. 最小二乘法概念和代码示例
  15. 扫荡倾斜摄影单体化难题
  16. 北大2011年计算机系录取浙江毛,湖州这11位同学被清华北大录取!
  17. 按照角度进行图片旋转
  18. 传奇服务器端如何修改称号,图文解说传奇人物称号设置详细步骤
  19. 爱贝云计费服务端接入
  20. Spark jar not loaded. Offending class: javax/servlet/Servlet.class

热门文章

  1. ssh的mysql分页查询_在SSH框架下按条件分页查询
  2. 去掉重复值php,php多维数组去掉重复值
  3. python程序设计pdf上海交大_上海交大2011_2012程序设计python期末考试题
  4. Barh函数--Matplotlib
  5. error C4703: 使用了可能未初始化的本地指针变量
  6. Linux系统centos6.7上安装libevent
  7. 跳石头 vijos1981 NOIP2015 D2T1 二分答案 模拟 贪心
  8. 找到好东西,可以显示最忙碌的java线程的脚本
  9. [APUE]进程关系(上)
  10. PE格式详细讲解5 - 系统篇05|解密系列