服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

java语言操作oracle数据库中的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);
   }
  }

扫描关注微信公众号