在线等:谁能给俺一段处理(读取和插入)oracle内clob的代码。

时间:2020-12-12 10:02:02
jdk版本1.4.2;oracle版本9i。用java.sql.Clob的setString()、setCharacterStream()有异常:不支持的特性。郁闷中,哪位能帮个忙,谢谢

8 个解决方案

#1


搞定了

#2


能不能提供代碼.

#3


呵呵

#4


简单得很,用了多次了:
                        java.sql.Clob clob = rs.getClob(attri.getFieldName());
                        if (clob != null) {
                            String value = clob.getSubString((long) 1, (int) clob.length());
                        } 

#5


转贴
========================
-------------------------------------------------------
有关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); 
    } 

 

#6


xiexie

#7


up

#8


conn.setAutoCommit(false); 
       query = "insert into clobtest_table(id,picstr) values(?,empty_clob())"; 
java.sql.PreparedStatement pstmt = conn.prepareStatement(query); 
pstmt.setString(1,"001"); 
一旦"001"处的值超过4000就失败了
这个方法不好

#1


搞定了

#2


能不能提供代碼.

#3


呵呵

#4


简单得很,用了多次了:
                        java.sql.Clob clob = rs.getClob(attri.getFieldName());
                        if (clob != null) {
                            String value = clob.getSubString((long) 1, (int) clob.length());
                        } 

#5


转贴
========================
-------------------------------------------------------
有关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); 
    } 

 

#6


xiexie

#7


up

#8


conn.setAutoCommit(false); 
       query = "insert into clobtest_table(id,picstr) values(?,empty_clob())"; 
java.sql.PreparedStatement pstmt = conn.prepareStatement(query); 
pstmt.setString(1,"001"); 
一旦"001"处的值超过4000就失败了
这个方法不好