Oracle中Blob和Clob

Posted kakaisgood

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle中Blob和Clob相关的知识,希望对你有一定的参考价值。

Blob是指二进制大对象也就是英文Binary Large Object的所写;
Clob是指大字符对象也就是英文Character Large Object的所写。
因此这两个类型都是用来存储大量数据而设计的,其中BLOB是用来存储大量二进制数据的;CLOB用来存储大量文本数据。

在JDBC中有两个接口对应数据库中的BLOB和CLOB类型,java.sql.Blob和java.sql.Clob。和你平常使用数据库一样你可以直接通过ResultSet.getBlob()方法来获取该接口的对象。与平时的查找唯一不同的是得到Blob或Clob的对象后,我们并没有得到任何数据,但是我们可以这两个接口中的方法得到数据。 
例如: 
Blob b=resultSet.getBlob(1); 
InputStream bin=b.getBinaryStream(); 
Clob c=resultSet.getClob(2); 
Reader cReader=c.getCharacterStream(): 
 
另外还有一种获取方法,不使用数据流,而是使用数据块。 
例如 
Blob b=resultSet.getBlob(1); 
byte data=b.getByte(0,b.length()); 
Clob c=resultSet.getClob(2); 
String str=c.getSubString(0,c.length());
在这里要说明一下,这个方法其实并不安全,如果你很细心的话,那很容易就能发现getByte()和getSubString()两个方法中的第二个参数都是int类型的,而BLOB和CLOB是用来存储大量数据的。而且Bolb.length()和Clob.length()的返回值都是long类型的,所以很不安全。

 
















以上是关于Oracle中Blob和Clob的主要内容,如果未能解决你的问题,请参考以下文章

如何更新没有根元素的clob oracle中的xml元素

帮我理解Oracle中CLOB和BLOB的区别

Oracle中Blob和Clob

oracle中blob,clob,nclob主要区别是啥?

如何在java中读取oracle blob

关于Oracle中的BLOB字段的问题