SQL 类型 CLOB 在 JavaTM 编程语言中的映射关系。SQL CLOB 是内置类型,它将 Character Large Object 存储为数据库表的某一行中的一个列值。默认情况下,驱动程序使用 SQL locator(CLOB) 实现 Clob 对象,这意味着 CLOB 对象包含一个指向 SQL CLOB 数据而不是数据本身的逻辑指针。Clob 对象在它被创建的事务处理期间有效。

CLOB 接口提供某些方法来获得 SQL CLOB (Character Large Object) 值长度、在客户端实现 CLOB 值以及搜索子字符串或 CLOB 值中的 CLOB 对象。接口 ResultSet、CallableStatement 和 PreparedStatement 中的方法(如 getClob 和 setClob)允许编程人员访问 SQL CLOB 值。此外,此接口还拥有更新 CLOB 值的方法。

Oracle中,Varchar2支持的最大字节数为4KB,所以对于某些长字符串的处理,我们需要用CLOB类型的字段,CLOB字段最大支持4GB。

还有其他几种类型:

blob:二进制,如果exe,zip

clob:单字节码,比如一般的文本文件.

nlob:多字节码,如UTF格式的文件.

以下就是对CLOG字段的操作方法,在我们的项目中帮助文档部分用到。

1、首先是写入

Java代码

/* 以下表PF_HELP_CONTENT中的HCONTENT字段时CLOB类型的 */

// 通过序列器生成帮助ID

Map map = Query.getMap("Select TO_CHAR(SEQ_HID.nextval) HID FROM DUAL ");

hid = String.valueOf(map.get("HID"));

//插入一条数据,注意CLOB字段,需要先插入一个空的clob类型 empty_clob(),然后再单独更新clob字段

sql ="Insert INTO PF_HELP_CONTENT(HID,HCONTENT) VALUES (?,empty_clob())  ";

try

{

//执行插入

rtn = DbUtils.executeUpdate(sql,hid);

/* 插入成功后,修改HCONTENT字段内容 */

//取得数据库连接

Connection conn = DbUtils.getConnection();

//手动提交

conn.setAutoCommit(false);

//定义ResultSet 和 Clob 变量

ResultSet rs =null;

oracle.sql.CLOB clob =null;

//更新SQL

String sqlclob ="Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

//hid是varchar2类型的,所以用setString

pstmt.setString(1,hid);

//执行update语句

rs= pstmt.executeQuery();

if(rs.next())

{

//取得刚才的HCONTENT的内容,也就是刚才添加的empty_clob()

clob = (oracle.sql.CLOB)rs.getClob(1);

}

//需要用clob.getCharacterOutputStream()流方式输出

Writer write = clob.getCharacterOutputStream();

//写入具体内容,helpform.getHContent() 存的是帮助的内容

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

//提交

conn.commit();

conn.close();

}

catch(Exception ex)

{

//.........

}

Java代码

/* 以下表PF_HELP_CONTENT中的HCONTENT字段时CLOB类型的 */

// 通过序列器生成帮助ID

Map map = Query.getMap("Select TO_CHAR(SEQ_HID.nextval) HID FROM DUAL ");

hid = String.valueOf(map.get("HID"));

//插入一条数据,注意CLOB字段,需要先插入一个空的clob类型 empty_clob(),然后再单独更新clob字段

sql ="Insert INTO PF_HELP_CONTENT(HID,HCONTENT) VALUES (?,empty_clob())  ";

try

{

//执行插入

rtn = DbUtils.executeUpdate(sql,hid);

/* 插入成功后,修改HCONTENT字段内容 */

//取得数据库连接

Connection conn = DbUtils.getConnection();

//手动提交

conn.setAutoCommit(false);

//定义ResultSet 和 Clob 变量

ResultSet rs =null;

oracle.sql.CLOB clob =null;

//更新SQL

String sqlclob ="Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

//hid是varchar2类型的,所以用setString

pstmt.setString(1,hid);

//执行update语句

rs= pstmt.executeQuery();

if(rs.next())

{

//取得刚才的HCONTENT的内容,也就是刚才添加的empty_clob()

clob = (oracle.sql.CLOB)rs.getClob(1);

}

//需要用clob.getCharacterOutputStream()流方式输出

Writer write = clob.getCharacterOutputStream();

//写入具体内容,helpform.getHContent() 存的是帮助的内容

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

//提交

conn.commit();

conn.close();

}

catch(Exception ex)

{

//.........

}/* 以下表PF_HELP_CONTENT中的HCONTENT字段时CLOB类型的 */

// 通过序列器生成帮助ID

Map map = Query.getMap("Select TO_CHAR(SEQ_HID.nextval) HID FROM DUAL ");

hid = String.valueOf(map.get("HID"));

//插入一条数据,注意CLOB字段,需要先插入一个空的clob类型 empty_clob(),然后再单独更新clob字段

sql = "Insert INTO PF_HELP_CONTENT(HID,HCONTENT) VALUES (?,empty_clob()) ";

try

{

//执行插入

rtn = DbUtils.executeUpdate(sql,hid);

/* 插入成功后,修改HCONTENT字段内容 */

//取得数据库连接

Connection conn = DbUtils.getConnection();

//手动提交

conn.setAutoCommit(false);

//定义ResultSet 和 Clob 变量

ResultSet rs = null;

oracle.sql.CLOB clob = null;

//更新SQL

String sqlclob = "Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

//hid是varchar2类型的,所以用setString

pstmt.setString(1,hid);

//执行update语句

rs= pstmt.executeQuery();

if(rs.next())

{

//取得刚才的HCONTENT的内容,也就是刚才添加的empty_clob()

clob = (oracle.sql.CLOB)rs.getClob(1);

}

//需要用clob.getCharacterOutputStream()流方式输出

Writer write = clob.getCharacterOutputStream();

//写入具体内容,helpform.getHContent() 存的是帮助的内容

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

//提交

conn.commit();

conn.close();

}

catch(Exception ex)

{

//.........

}

2、修改CLOB字段内容

Java代码

/* 修改跟插入时基本一致,也是用for update来实现 */

//如果修改前的字段内容长度大于当前修改的长度时,末尾的部分内容仍然会存在

//所以在修改内容前,需要将PF_HELP_CONTENT内容置空

sql =" Update PF_HELP_CONTENT SET HCONTENT=empty_clob() Where HID=? ";

try

{

rtn = DbUtils.executeUpdate(sql,hid);

//以下操作跟添加时一样

Connection conn = DbUtils.getConnection();

conn.setAutoCommit(false);

ResultSet rs =null;

oracle.sql.CLOB clob =null;

String sqlclob ="Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

pstmt.setString(1,hid);

rs= pstmt.executeQuery();

if(rs.next())

{

clob = (oracle.sql.CLOB)rs.getClob(1);

}

Writer write = clob.getCharacterOutputStream();

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

conn.commit();

conn.close();

}

catch(Exception ex)

{

//...

}

Java代码

/* 修改跟插入时基本一致,也是用for update来实现 */

//如果修改前的字段内容长度大于当前修改的长度时,末尾的部分内容仍然会存在

//所以在修改内容前,需要将PF_HELP_CONTENT内容置空

sql =" Update PF_HELP_CONTENT SET HCONTENT=empty_clob() Where HID=? ";

try

{

rtn = DbUtils.executeUpdate(sql,hid);

//以下操作跟添加时一样

Connection conn = DbUtils.getConnection();

conn.setAutoCommit(false);

ResultSet rs =null;

oracle.sql.CLOB clob =null;

String sqlclob ="Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

pstmt.setString(1,hid);

rs= pstmt.executeQuery();

if(rs.next())

{

clob = (oracle.sql.CLOB)rs.getClob(1);

}

Writer write = clob.getCharacterOutputStream();

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

conn.commit();

conn.close();

}

catch(Exception ex)

{

//...

}/* 修改跟插入时基本一致,也是用for update来实现 */

//如果修改前的字段内容长度大于当前修改的长度时,末尾的部分内容仍然会存在

//所以在修改内容前,需要将PF_HELP_CONTENT内容置空

sql = " Update PF_HELP_CONTENT SET HCONTENT=empty_clob() Where HID=? ";

try

{

rtn = DbUtils.executeUpdate(sql,hid);

//以下操作跟添加时一样

Connection conn = DbUtils.getConnection();

conn.setAutoCommit(false);

ResultSet rs = null;

oracle.sql.CLOB clob = null;

String sqlclob = "Select HCONTENT FROM PF_HELP_CONTENT Where HID=? FOR Update ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

pstmt.setString(1,hid);

rs= pstmt.executeQuery();

if(rs.next())

{

clob = (oracle.sql.CLOB)rs.getClob(1);

}

Writer write = clob.getCharacterOutputStream();

write.write(helpform.getHContent());

write.flush();

write.close();

rs.close();

conn.commit();

conn.close();

}

catch(Exception ex)

{

//...

}

3、取出CLOB字段的文本内容

Java代码

/* 前面部分都一致 */

Connection conn = DbUtils.getConnection();

conn.setAutoCommit(false);

ResultSet rs =null;

oracle.sql.CLOB clob =null;

String sqlclob ="Select HCONTENT FROM PF_HELP_CONTENT Where HID=? ";

java.sql.PreparedStatement pstmt = conn.prepareStatement(sqlclob);

pstmt.setString(1,hid);

rs= pstmt.executeQuery();

if(rs.next())

{

//rs.getClob(1)中参数1指的是HCONTENT字段索引,第一个字段从1开始而不是从0。

//也可以用字段名来取rs.getClob("HCONTENT")

clob = (oracle.sql.CLOB)rs.getClob(1);

}

if(clob==null|| clob.length()==0)

{

hcontent ="";

}else

{

//取CLOB字段内容为字符串

hcontent=clob.getSubString((long)1,(int)clob.length());

}

rs.close();

conn.close();

request.setAttribute("HCONTENT",hcontent);

java clob类型怎么插入数据库_在Java + Oracle环境下 对于clob类型的数据的插入相关推荐

  1. java文件流插入数据库_使用Java流查询数据库

    java文件流插入数据库 在本文中,您将学习如何编写纯Java应用程序,这些应用程序能够处理现有数据库中的数据,而无需编写一行SQL(或类似的语言,例如HQL),而无需花费数小时将所有内容放在一起. ...

  2. 问题解决:枚举值插入数据库时报错 java.lang.IllegalArgumentException: invalid comparison: XXEnum and java.lang.String

    问题描述:出现了一个问题,将枚举类型的值插入数据库后,报出了下面这个错误 java.lang.RuntimeException: nested exception is org.apache.ibat ...

  3. java关于泛型的实验代码_[改善Java代码]强制声明泛型的实际类型

    Arrays工具类有一个方法asList可以把一个变长参数或数组变成列表,但是它有一个缺点:它所生成的List长度是不可改变的,而这在我们的项目开发中很不方便. importjava.util.Arr ...

  4. Java中怎样创建数据库_在java中怎样创建MySQL数据库列表给个例子 爱问知识人

    java中怎样创建MySQL数据库列表 需要使用jdbc访问数据库. 具体步骤如下: 1:加载驱动 ,返回连接 private static final String DRIVER_CLASS = & ...

  5. java 读取mysql数据库_原生Java操作mysql数据库过程解析

    这篇文章主要介绍了原生Java操作mysql数据库过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.引入数据库驱动的jar包 以通过mav ...

  6. java 判断文件类型是否是音频_用java流方式判断文件类型

    这个方法只能在有限的范围内有效.并不是万金油 比如 图片类型判断,音频文件格式判断,视频文件格式判断等这种肯定是2进制且专业性很强的文件类型判断. 下面给出完整版代码 首先是文件类型枚取 packag ...

  7. java创建access数据库_使用Java创建Access数据库文件(.mdb或.accdb)

    Jackcess 2.x的更新:现在使用DatabaseBuilder创建(或打开)数据库,因此要创建一个新的数据库文件,我们这样做 import java.io.File; import java. ...

  8. java解析xml中文字符乱码_各种Java中文乱码的处理方法

    对于Java,由于默认的编码方式是UNICODE,所以用中文也易出问题,常见的解决是: String s2 = new String(s1.getBytes("ISO-8859-1" ...

  9. java 必须try catch的异常_【java基础之异常】死了都要try,不淋漓尽致地catch我不痛快!...

    @ 1.异常 1.1 异常概念 异常 :简单说就是不正常运行,最终导致JVM的非正常停止. 在Java等面向对象的编程语言中,异常本身是一个类,产生异常就是创建异常对象并抛出了一个异常对象.Java处 ...

最新文章

  1. 快速创建包快捷键大全_99个CAD插件大全,各种工具箱和超实用辅助插件,绘图从此不卡顿...
  2. django权限系统实现步骤_Django权限机制的实现
  3. BackgroundWorker
  4. WPF应用程序内嵌网页
  5. 腾讯2016春招安全岗笔试题解析
  6. 一文看懂Java锁机制
  7. JAVA bridge设计模式,java设计模式之Bridge
  8. 微信公众开放平台开发02---微信公众平台PHP接口和java接口对比
  9. 30个常用python实现
  10. C++的占位符std::placeholder
  11. 因不满被拒,研究员公开 IBM 企业安全软件中的4个 0day
  12. 编程之美-2.4 1的数目
  13. JS前端加密JAVA后端解密详解
  14. 通俗地告诉你:为什么Dijkstra算法是正确的?
  15. 斐讯M1,nodered打包显示在homekit
  16. 借助方便的工具平台,让App制作变简单
  17. DINGWAVE发布口袋式软件无线电解决方案
  18. Oracle生成data patching脚本
  19. OpenCL入门二:OpenCL基础概念
  20. 阿里专家20讲,玩转一站式实时数仓Hologres训练营(限量免费)

热门文章

  1. 将数据生成带图表的pdf,并下载
  2. php输入中文就乱码,在php图片中输入中文文字解决乱码
  3. (力扣C++)动态规划学习计划
  4. 江苏工程职业技术学院计算机专业,江苏工程职业技术学院
  5. 计算机桌面底部图标不见了怎么办,电脑下面那一排图标不见了?怎么处理?
  6. 人民币对美元中间价“三连升” 合计涨近千个基点
  7. What's UTF-8?
  8. 跟Steve Jobs学简报,全1-5
  9. usaco Horseshoes
  10. puppeteer生成PDF