java操作数据库中clob类型 之插入和查询

原创 2015年11月17日 16:52:31

一、插入

1)对于clob字段,首先插入empty_clob();
String sql = " insert into batchintfloadlog (centercode,filename,policydate,starttime,endtime,resultinfo) values ('"
+ this.ywBranchCode.substring(0, 4).concat("0000") + "','"
+ this.dataType + "',date '"
+ this.policyDate + "',"
+ "'"+ this.loadTime + "','"+ endtime +"',"
+ "empty_clob()";
ExeSQL eSQL = new ExeSQL(conn1);
eSQL.execUpdateSQL(sql);
//提前提交,防止插入日志发生异常时,日志表中无任何记录
//若发现resultinfo字段为null.则表明提交之后,插入日志方法insertIntfLoadLog()发生异常

//当然此处也可以不提交(业务需要)

try {
conn1.commit();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
2)使用select...forupdate语句查询(目的是查询并锁定当前数据行以便更新)
String sql2 = "select resultinfo from batchintfloadlog a where " +
"a.centercode='"+ this.ywBranchCode.substring(0, 4).concat("0000") + "' " +
"and a.filename='"+ this.dataType + "' " +
"and a.policydate= date'"+ this.policyDate +"' " +
"and a.starttime='"+ this.loadTime +"' and a.endtime='"+ endtime +"'" +
"for update";
try {
pstmt = conn1.prepareStatement(sql2);
rs = pstmt.executeQuery();
pstmt = null;

if(rs.next()){

Object obj = rs.getObject(1);
if("oracle.sql.CLOB".equals(obj.getClass().getName())){
clob = (CLOB) rs.getClob(1);
}<span style="font-family: Arial, Helvetica, sans-serif;"> </span>
<span style="white-space:pre"> </span>//else if("weblogic.jdbc.wrapper.Clob_oracle_sql_CLOB".equals(obj.getClass().getName())){
// Method method = obj.getClass().getMethod("getVendorObj",new Class[]{}); 
// clob = (CLOB) method.invoke(obj);
//}
//其中1表示的是sql3中的第几个问号
clob.putString(1, eMessage);
String sql3 = "update batchintfloadlog a set a.resultinfo=? where " +
"a.centercode='"+ this.ywBranchCode.substring(0, 4).concat("0000") + "' " +
"and a.filename='"+ this.dataType + "' " +
"and a.policydate= date'"+ this.policyDate +"' " +
"and a.starttime='"+ this.loadTime +"' and a.endtime='"+ endtime +"'";
pstmt = conn1.prepareStatement(sql3);
pstmt.setClob(1, clob);
pstmt.executeUpdate();
//提交
conn1.commit();
closeMethod(rs, pstmt,conn1);
}
} catch (Exception e) {
try {
conn1.rollback();
} catch (Exception e1) {
e1.printStackTrace();
}
closeMethod(rs, pstmt,conn1);
e.printStackTrace();
}
总结: i.先把clob字段类型给空出来,取而代之的是empty_clob(),插入数据库中

ii.使用select...for update把刚插入的数据给查出来,for update目的锁定当前数据行

iii.使用getObject(index)方法获得clob字段的引用C
iv.之后 ,对引用赋值 C.pubString(1,value);
v.pstmt.setClob(C);赋值
vi.conn.commit;//提交
二、查询

相对来说查询比较简单,就直接getString即可

rs.getString("clobField");
可参考:点击打开链接


相关文章推荐

Java对Oracle中Clob类型数据的读取和写入

Java对Oracle中Clob数据类型是不能够直接插入的,但是可以通过流的形式对clob类型数据写入或者读取,网上代码并不算特别多,讲的也不是很清楚,我对网上资料进行了整理和总结,具体看代码: ...

java插入内容进入oracle的clob字段

1. 背景自己在拷贝数据表内容,进入另外一个数据库时。2. 说明java给oracle的clob字段插入内容。3. 代码片段获取clob字段内容:public static ArrayList doE...

java插入clob字段

1)clob类型的数据不能直接insert,要先通过empty_clob()方法给它分配一个locator(同理,blob的用empty_blob()函数分配locator).然后把它select出来...

在oracle数据库中如何插入CLOB值

        oracle中最常用的varcher2类型最多只能存储4000个字节的内容,一般情况下是能够满足用户的需求的。但是在一些特殊情况下(如要存储图片或者要存储的内容超过了4000个字节),...
  • CMTobby
  • CMTobby
  • 2005年07月27日 18:11
  • 6622

ORACLE 还有BLOB及CLOB等类型字段的表的导出导入

当ORACLE数据库导出的时候,发现有些表有BLOB和CLOB类型字段的时候,利用一般的导出方法是无法导出的会报错,其原因是sql无法生成这两种类型字段,这个时候,最好用的方法就是plsql自带的导出...

插入和读取blob和clob类型数据

/******************blob*********************/ public class Blob_Test { //创建表 @Test publi...

jdbc插入修改clob类型的两种方式

方法一: Connection con = dbl.loadConnection(); strSql = "insert into table1(id,a) values (1,EMPTY_CLOB(...

CLOB字段的插入以及更新操作

1.  插入方法,首先需要先插入一个空的CLOB对象,之后查询出该条对象,并进行更新操作: @Override public void add(Object obj) throws DAOExc...

Oracle 插入CLOB字段的简易写法(纯脚本操作插入到CLOB字段)

版本:oracle 10g,11g 操作方式:spring jdbctemplate / jdbc 需求:项目模块中需要将字符插入到数据库,起初字符只有几百个字符,随着项目的进展,出现了4...

oracle CLOB类型超过4000个字段sql插入方法

DECLARE vString ta_config_bigvalue.config_context%type; BEGIN vString := '...8000个字符.....'; INS...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java操作数据库中clob类型 之插入和查询
举报原因:
原因补充:

(最多只允许输入30个字)