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

lianglijun2008

lianglijun2008

2016-02-19 15:39

最近很多朋友喜欢上设计,但是大家却不知道如何去做,别担心有图老师给你解答,史上最全最棒的详细解说让你一看就懂。

  字段类型:blob,clob,nclob

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/bianchengyuyan/)

  说明:三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行读取、存储、写入等非凡操作。
  
  我们所操作的cloBTest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。
  
  代码:   
  
  (1)对数据库clob型执行插入操作

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/bianchengyuyan/)

  *************************************************
  
  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);
   }
  }

展开更多 50%)
分享

猜你喜欢

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

编程语言 网络编程
java语言操作Oracle数据库中的CLOB数据类型

Java语言数据库操作的基本流程

编程语言 网络编程
Java语言数据库操作的基本流程

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

MySQL数据库基础:数据类型及列类型

MySQL mysql数据库
MySQL数据库基础:数据类型及列类型

在JAVA中连接Oracle数据库(例子)

编程语言 网络编程
在JAVA中连接Oracle数据库(例子)

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

java数据类型转换

Java JAVA基础
java数据类型转换

Oracle数据库数据对象分析(中)

编程语言 网络编程
Oracle数据库数据对象分析(中)

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

[JAVA100例]024、颜色过滤器

[JAVA100例]024、颜色过滤器

JS+CSS打造可拖动的聊天窗口层

JS+CSS打造可拖动的聊天窗口层
下拉加载更多内容 ↓