广

oracle数据库

  • MYSQL
  • MSSQL
  • Redis
  • MongoDB
  • oracle数据库
  • 数据管理

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

    2018-04-09 07:41:42 次阅读 稿源:互联网
    广告
    全网推广平台,软文发布

      字段类型: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);
       }
      }

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告
    广告