文档章节

Clob,Blob,InputStream,byte 互转

zimingforever
 zimingforever
发布于 2012/10/06 11:20
字数 524
阅读 8143
收藏 2

今天用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,对应着输入流和二进制数组。

© 著作权归作者所有

zimingforever
粉丝 142
博文 266
码字总数 315040
作品 0
杭州
程序员
私信 提问
加载中

评论(1)

web菜鸟
web菜鸟
通过JDBC和Hibernate对Clob和Blob的操作

本文主要简介通过JDBC和Hibernate对Clob和Blob的操作,插入和读取. 一,JDBC方式: 1,当lob的内容很小的时候,用sta.setString(2, "clob content"); sta.setBytes(3, "blob".getBytes()); 2,通过......

晨曦之光
2012/04/25
923
0
保存图片、文本到数据表中去

Pst对象保存大对象:BLOB - Binaray Larg Object - > 大的二进制类型 > 4GCLOB - Character larg Object - > 大的字符类型 - > 4G 1:保存一个图片到数据表中去 – Blobcreate table users(n......

CarlDing
2016/03/29
12
0
Spring 数据库处理Clob/Blob大对象

概述 使用Spring的时候需求上难免说需要存储一下几种类型: 文本 图片 二进制 --- 处理对象 Spring 支持通过进行处理大对象 BLOB byte[] — getBlobAsBytes and setBlobAsBytes InputStre...

小彬彬_
2016/09/10
54
0
dbutils实现clob和blob存储

//使用dbutils实现大文本对象的存储. @Test public void testClob() throws Exception{ String sql="insert into article (content)values(?)"; File file=new File("bin/stylesheet.css");......

又右耳刀
2013/11/08
572
0
Oracle中JDBC对BLOB和CLOB读取的专用处理和通用处理

设有表: create table blobimg (id int primary key, contents blob); 一、BLOB入库的专用访问: 1) 最常见于Oracle的JDBC示例中 一般是先通过select ... for update锁定blob列,然后写入b...

晨曦之光
2012/04/12
240
0

没有更多内容

加载失败,请刷新页面

加载更多

搭建高可用MongoDB集群(分片)

搭建高可用MongoDB集群(分片) MongoDB基础请参考:https://blog.51cto.com/kaliarch/2044423 MongoDB(replica set)请参考:https://blog.51cto.com/kaliarch/2044618 一、概述 1.1 背景 ......

linjin200
26分钟前
5
0
CDH6.0.1集成tez-0.9.1计算引擎

参考文章: https://www.jianshu.com/p/9fb9f32e1f0f https://www.baidu.com/link?url=OgpwasnZi7H1dySN2T111sseEWDBaCCTC3DFV61G7756YbrkJCA8Y3UFaueyqnfN&wd=&eqid=daeb8b3500049cf3000000......

Sheav
28分钟前
4
0
Vue内置指令的使用

v-model(数据绑定) v-model常用于表单数据的双向绑定,它本质上是一个语法糖。它主要的有两种应用: 在文本框、多行文本、input的下拉框、单选按钮、复选框中的应用 <div id="app"> ...

凌兮洛
29分钟前
5
0
外部来源应用检查-烦死了,终于找到解决设置了

Android 连接usb调试应用的时候: 华为关闭方法:1、设置-安全-更多安全设置,关掉外部来源应用检查。2、设置-系统-开发人员选项-关闭“监控ADB安装应用” 不知道OPPO 怎么关闭的?...

QGlaunch
30分钟前
4
0
6个K8s日志系统建设中的典型问题,你遇到过几个?

作者 | 元乙 阿里云日志服务数据采集客户端负责人,目前采集客户端 logtail 在集团百万规模部署,每天采集上万应用数 PB 数据,经历多次双 11、双 12 考验。 导读:随着 K8s 不断更新迭代,使...

阿里云官方博客
32分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部