博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CLOB字段在java中操作
阅读量:7048 次
发布时间:2019-06-28

本文共 3233 字,大约阅读时间需要 10 分钟。

hot3.png

1、往数据库中插入一个新的CLOB对象     
  public   static   void   clobInsert(String   infile)   throws   Exception     
  {     
  /*   设定不自动提交   */     
  boolean   defaultCommit   =   conn.getAutoCommit();     
  conn.setAutoCommit(false);     
  try   {     
  /*   插入一个空的CLOB对象   */     
  stmt.executeUpdate("INSERT   INTO   TEST_CLOB   VALUES   (’111’,   EMPTY_CLOB())");     
  /*   查询此CLOB对象并锁定   */     
  ResultSet   rs   =   stmt.executeQuery("SELECT   CLOBCOL   FROM   TEST_CLOB   WHERE   ID=’111’   FOR   UPDATE");     
  while   (rs.next())   {     
  /*   取出此CLOB对象   */     
  oracle.sql.CLOB   clob   =   (oracle.sql.CLOB)rs.getClob("CLOBCOL");     
  /*   向CLOB对象中写入数据   */     
  BufferedWriter   out   =   new   BufferedWriter(clob.getCharacterOutputStream());     
  BufferedReader   in   =   new   BufferedReader(new   FileReader(infile));     
  int   c;     
  while   ((c=in.read())!=-1)   {     
  out.write(c);     
  }     
  in.close();     
  out.close();     
  }     
  /*   正式提交   */     
  conn.commit();     
  }   catch   (Exception   ex)   {     
  /*   出错回滚   */     
  conn.rollback();     
  throw   ex;     
  }     
  /*   恢复原提交状态   */     
  conn.setAutoCommit(defaultCommit);     
  }     
  2、修改CLOB对象(是在原CLOB对象基础上进行覆盖式的修改)     
  public   static   void   clobModify(String   infile)   throws   Exception     
  {     
  /*   设定不自动提交   */     
  boolean   defaultCommit   =   conn.getAutoCommit();     
  conn.setAutoCommit(false);     
  try   {     
  /*   查询CLOB对象并锁定   */     
  ResultSet   rs   =   stmt.executeQuery("SELECT   CLOBCOL   FROM   TEST_CLOB   WHERE   ID=’111’   FOR   UPDATE");     
  while   (rs.next())   {     
  /*   获取此CLOB对象   */     
  oracle.sql.CLOB   clob   =   (oracle.sql.CLOB)rs.getClob("CLOBCOL");     
  /*   进行覆盖式修改   */     
  BufferedWriter   out   =   new   BufferedWriter(clob.getCharacterOutputStream());     
  BufferedReader   in   =   new   BufferedReader(new   FileReader(infile));     
  int   c;     
  while   ((c=in.read())!=-1)   {     
  out.write(c);     
  }     
  in.close();     
  out.close();     
  }     
  /*   正式提交   */     
  conn.commit();     
  }   catch   (Exception   ex)   {     
  /*   出错回滚   */     
  conn.rollback();     
  throw   ex;     
  }     
  /*   恢复原提交状态   */     
  conn.setAutoCommit(defaultCommit);     
  }     
    3、替换CLOB对象(将原CLOB对象清除,换成一个全新的CLOB对象)     
  public   static   void   clobReplace(String   infile)   throws   Exception     
  {     
  /*   设定不自动提交   */     
  boolean   defaultCommit   =   conn.getAutoCommit();     
  conn.setAutoCommit(false);     
  try   {     
  /*   清空原CLOB对象   */     
  stmt.executeUpdate("UPDATE   TEST_CLOB   SET   CLOBCOL=EMPTY_CLOB()   WHERE   ID=’111’");     
  /*   查询CLOB对象并锁定   */     
  ResultSet   rs   =   stmt.executeQuery("SELECT   CLOBCOL   FROM   TEST_CLOB   WHERE   ID=’111’   FOR   UPDATE");     
  while   (rs.next())   {     
  /*   获取此CLOB对象   */     
  oracle.sql.CLOB   clob   =   (oracle.sql.CLOB)rs.getClob("CLOBCOL");     
  /*   更新数据   */     
  BufferedWriter   out   =   new   BufferedWriter(clob.getCharacterOutputStream());     
  BufferedReader   in   =   new   BufferedReader(new   FileReader(infile));     
  int   c;     
  while   ((c=in.read())!=-1)   {     
  out.write(c);     
  }     
  in.close();     
  out.close();     
  }     
  /*   正式提交   */     
  conn.commit();     
  }   catch   (Exception   ex)   {     
  /*   出错回滚   */     
  conn.rollback();     
  throw   ex;     
  }     
  /*   恢复原提交状态   */     
  conn.setAutoCommit(defaultCommit);     
  }     
  4、CLOB对象读取     
  public   static   void   clobRead(String   outfile)   throws   Exception     
  {     
  /*   设定不自动提交   */     
  boolean   defaultCommit   =   conn.getAutoCommit();     
  conn.setAutoCommit(false);     
  try   {     
  /*   查询CLOB对象   */     
  ResultSet   rs   =   stmt.executeQuery("SELECT   *   FROM   TEST_CLOB   WHERE   ID=’111’");     
  while   (rs.next())   {     
  /*   获取CLOB对象   */     
  oracle.sql.CLOB   clob   =   (oracle.sql.CLOB)rs.getClob("CLOBCOL");     
  /*   以字符形式输出   */     
  BufferedReader   in   =   new   BufferedReader(clob.getCharacterStream());     
  BufferedWriter   out   =   new   BufferedWriter(new   FileWriter(outfile));     
  int   c;     
  while   ((c=in.read())!=-1)   {     
  out.write(c);     
  }     
  out.close();     
  in.close();     
  }     
  }   catch   (Exception   ex)   {     
  conn.rollback();     
  throw   ex;     
  }     
  /*   恢复原提交状态   */     
  conn.setAutoCommit(defaultCommit);     
  }    

转载于:https://my.oschina.net/yululaile/blog/56004

你可能感兴趣的文章
内存管理[6]
查看>>
NIS服务器配置案例
查看>>
Objective-C之成魔之路【15-Foundation框架】
查看>>
c#开发之四---ado.net
查看>>
iOS7 edgesForExtendedLayout
查看>>
OpenCV计算机视觉库
查看>>
Swift - 获取当前的ViewController
查看>>
filter-Policy 实验
查看>>
Spark算子:RDD键值转换操作(2)–combineByKey、foldByKey
查看>>
解读SUID权限位
查看>>
LRU缓存介绍与实现 (Java)
查看>>
我的友情链接
查看>>
Android系统学习总结2--Binder 机制
查看>>
如何打开MDI子窗口时,不显示窗口由小变大的过程
查看>>
MongoDB(三):创建、更新及删除文档
查看>>
Maven项目部署问题
查看>>
关于百度坐标系 (BD-09)与火星坐标系 (GCJ-02)以及WGS84坐标之间的互相转换
查看>>
I'm BACK NOW
查看>>
oracle管理之ASM
查看>>
BGP MPLS ×××
查看>>