java语言操作Oracle数据库中的CLOB数据类型

原创 2002年12月13日 09:07:00

有关oracle字段类型的相关信息可以查阅oracle技术网。下面摘抄一些有关blob.clob等类型的说明。又便于大家的了解。
字段类型:blob,clob,nclob
说明:三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行读取、存储、写入等特殊操作。

我们所操作的clobtest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。

代码:
 
 
(1)对数据库clob型执行插入操作
*************************************************
 
java.sql.PreparedStatement pstmt = null;
ResultSet rs = null;
String query = "";
 
conn.setAutoCommit(false);
       query = "insert into clobtest_table(id,picstr) values(?,empty_clob())";
java.sql.PreparedStatement pstmt = conn.prepareStatement(query);
pstmt.setString(1,"001");
pstmt.executeUpdate();
pstmt = null
       query = "select picstr from clobtest_table where id = '001' for update";
pstmt = con.prepareStatement(query)
rs= pstmt.executeQuery();
 
oracle.sql.CLOB clobtt = null;
if(rs.next()){
    clobtt = (oracle.sql.CLOB)rs.getClob(1);
}
Writer wr = clobtt.getCharacterOutputStream();
wr.write(strtmp);
wr.flush();
wr.close();
rs.close();
con.commit();
 
 
 
(2)通过sql/plus查询是否已经成功插入数据库
*************************************************
 
PL/SQL的包DBMS_LOB来处理LOB数据。察看刚才的插入是否成功。使用DBMS_LOB包的getlength这个procedure来检测是否已经将str存入到picstr字段中了。如:
 
SQL> select dbms_lob.getlength(picstr) from clobtest_table;
 
 
(3)对数据库clob型执行读取操作
*************************************************
 
读取相对插入就很简单了。基本步骤和一半的取数据库数据没有太大的差别。
String description = ""
      query = "select picstr from clobtest_table where id = '001'";
pstmt = con.prepareStatement(query);
ResultSet result = pstmt.executeQuery();
if(result.next()){
    oracle.jdbc.driver.OracleResultSet ors =  
              (oracle.jdbc.driver.OracleResultSet)result;
    oracle.sql.CLOB clobtmp = (oracle.sql.CLOB) ors.getClob(1);
 
    if(clobtmp==null || clobtmp.length()==0){
        System.out.println("======CLOB对象为空 ");
        description = "";
    }else{
        description=clobtmp.getSubString((long)1,(int)clobtmp.length());
        System.out.println("======字符串形式 "+description);
    }
}
 

java语言操作Oracle数据库中的CLOB数据类型

有关oracle字段类型的相关信息可以查阅oracle技术网。下面摘抄一些有关blob.clob等类型的说明。又便于大家的了解。字段类型:blob,clob,nclob说明:三种大型对象(LOB),用...
  • lbh198408
  • lbh198408
  • 2007年06月26日 14:16
  • 651

oracle导出含有Clob大数据字段类型的问题

在使用oracle数据库的时候,经常会遇到类似CLOB、NLOB、BLOB等大数据类型字段,但是当你想要导出含有该字段类型的数据时,会发现导出来该列字段的数据都显示成了CLOB类型。那么如何处理呢? ...
  • u013519551
  • u013519551
  • 2016年08月01日 13:54
  • 3343

oracle数据库的blob和clob类型,是什么意思和区别

BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的。其实两个是可以互换的的,或者可以直接用LOB字段代替这两个。但是为了更好的管理ORACLE数据库,通常像图...
  • Ideality_hunter
  • Ideality_hunter
  • 2016年10月25日 15:23
  • 2397

oracle中对clob字段的操作

1.clob字段插入值create or replace procedure updateclob(table_name in varchar2,field_id in varchar2,field_...
  • terryhuang
  • terryhuang
  • 2008年04月24日 14:30
  • 635

ORACLE读写CLOB(oracle存储XML文件)

把一个XML文件写入到ORACLE中 : SessionFactory factory=this.getHibernateTemplate().getSessionFactory(); Sessio...
  • enterys
  • enterys
  • 2013年04月25日 10:06
  • 3833

浅谈Java语言中八种基本数据类型

1.布尔型-----boolean,boolean 类型所占存储空间的大小没有明确指定,其取值为true或false,其默认值为false。 2.字节型----byte,byte 类型所占存储空间大小...
  • hs2201056
  • hs2201056
  • 2017年02月28日 22:05
  • 1683

对于oracle数据库中怎么查看clob类型的值

1、在Plsql里找到要看的表点编辑数据选中要找到的列右击在编辑器中打开如图所示。 2、点击进去看到就是里面存的真实值,如图所示。...
  • u011897081
  • u011897081
  • 2017年08月17日 16:57
  • 619

oracle wmsys.wm_concat ORA-00932: 数据类型不一致: 应为 -, 但却获得 CLOB

oracle 函数 wmsys.wm_concat 在 10.2.0.4版本以前是 varchar2 类型,但是 从 10.2.0.5 开始,是 CLOB 类型,是一个坑!! 改成 to_char(...
  • YangYudong2014
  • YangYudong2014
  • 2017年03月13日 11:13
  • 2688

ORA-00932: 数据类型不一致: 应为 -, 但却获得 CLOB

出错语句如下所示: create table fetch_bank_concat_ethan as select fuid,count(*) bb_num,cast(WMSYS.WM_CONCAT( ...
  • u010736419
  • u010736419
  • 2013年08月26日 17:03
  • 6494

Oracle中对clob类型字段的操作

下面这篇文章说的很详细,我再做两点补充说明:        第一,LOB数据不能象其它类型数据一样直接插入(INSERT)。插入前必须先插入一个空的LOB对象,CLOB类型的空对象为EMPTY_CLO...
  • sdliubo
  • sdliubo
  • 2005年02月02日 16:49
  • 8988
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java语言操作Oracle数据库中的CLOB数据类型
举报原因:
原因补充:

(最多只允许输入30个字)