Clob,Blob,InputStream,byte 互转

本文详细介绍了使用Java从Oracle数据库中读取Clob字段,并将其转换为XML文件的方法,包括Blob与Clob之间的相互转换,以及如何通过流进行数据的读取与写入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天用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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值