用JDBC写的CLOB存取类

表CLOB_TEST
ID NUMBER;
CONTENT CLOB;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import oracle.sql.CLOB;

public class JDBCTest {
 /**
  * @param args
  */
 public static void main(String[] args) {
  insert();
  query();
  
 }
 
 public static void insert(){
  try {
   String driver = "oracle.jdbc.driver.OracleDriver";
   String url = "jdbc:oracle:thin:@192.168.1.253:1521:alphadb";
   String username = "alpha";
   String password = "alpha2012";
   
   Class.forName(driver);
   Connection conn = DriverManager.getConnection(url, username, password);
   String sql = "insert into CLOB_TEST VALUES(?, empty_clob())";
   
    //禁用自动提交事务  
            conn.setAutoCommit(false);  
   PreparedStatement pstmt = conn.prepareStatement(sql);
   pstmt.setInt(1, 3);
   int ret = pstmt.executeUpdate();
   System.out.println(ret);
   pstmt.close();
   
   //查询并获得这个cursor,并且加锁  
            sql="SELECT CONTENT FROM CLOB_TEST WHERE ID=? for update";  
            pstmt = conn.prepareStatement(sql);
            pstmt.setInt(1, 3);
   ResultSet rs = pstmt.executeQuery();
   CLOB clob = null;
   while(rs.next()) {
//    System.out.println(rs.getInt(1));
    clob = (CLOB)rs.getClob(1);
   }
   
   PrintWriter out = new PrintWriter(clob.getCharacterOutputStream());
   out.println("HI CLOB");
   out.flush();
   out.close();
   
   pstmt.close();
   
   
   sql = "UPDATE CLOB_TEST SET CONTENT = ? WHERE ID = ?";
   pstmt = conn.prepareStatement(sql);
   pstmt.setClob(1, clob);
   pstmt.setInt(2, 2);
   ret = pstmt.executeUpdate();
   System.out.println(ret);
   conn.commit();
   pstmt.close();
   
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }
 
 public static void query(){
  try {
   String driver = "oracle.jdbc.driver.OracleDriver";
   String url = "jdbc:oracle:thin:@192.168.1.253:1521:alphadb";
   String username = "alpha";
   String password = "alpha2012";
   
   Class.forName(driver);
   Connection conn = DriverManager.getConnection(url, username, password);
   String sql = "SELECT * FROM CLOB_TEST WHERE ID = ?";
   
   PreparedStatement pstmt = conn.prepareStatement(sql);
   pstmt.setInt(1, 3);
   ResultSet rs = pstmt.executeQuery();
   CLOB clob = null;
   while(rs.next()) {
    System.out.println(rs.getInt("ID"));
    clob = (CLOB)rs.getClob("CONTENT");
   }
   BufferedReader in = new BufferedReader(clob.getCharacterStream());
   String line = "";
   while((line = in.readLine()) != null){
    System.out.println(line);
   }
   rs.close();
   pstmt.close();
   
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值