关于jsp读取oracle的nclob类型字段的问题 我通过insert语句把值插入到表中是没问题的,但是,如果我读取数据库,用rs.getString("字段名")的方式读取,则只能得到null,请问高手如何正确读取nclob字段? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 nclob字段没有值的时候是empty_clob(),不是NULL 要转变格式,象这样看看;(oracle.sql.CLOB)rs.getClob("字段名"); 字段类型:blob,clob,nclob 说明:三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行 我们所操作的clobtest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。 代码: (1)对数据库clob型执行插入操作 ************************************************* java.sql.PreparedStatement pstmt = ; ResultSet rs = ; 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 = query = "select picstr from clobtest_table where id = '001' for pstmt = con.prepareStatement(query) rs= pstmt.executeQuery(); oracle.sql.CLOB clobtt = ; 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== || clobtmp.length()==0){ System.out.println("======CLOB对象为空 "); description = ""; }else{ description=clobtmp.getSubString((long)1,(int)clobtmp.length()); System.out.println("======字符串形式 "+description); } } weblogic部署的程序,访问是url后面反斜杠问题 Runtime.getRuntime().exec怪问题? java中如何用html打开别的文件类型 关于数据库关闭 提取HTML中的链接 servlet获得response的数据 做个最简单的投票,到最后想不出总票数这么算? 如何将url中的等号转义 求推荐开源的问题管理系统 servlet在主目录下可以执行,在虚拟目录下不能执行,为什么??? 渴求一个webwork+spring+hibernate的简单例子,谢谢 在WINDOW下可以实现水印,但在LINUX下不成功,难道这就是JSP的平台无关性?
象这样看看;
(oracle.sql.CLOB)rs.getClob("字段名");
说明:三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如
Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决
于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行
我们所操作的clobtest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个
大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经
建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下
api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。
代码:
(1)对数据库clob型执行插入操作
*************************************************
java.sql.PreparedStatement pstmt = ;
ResultSet rs = ;
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 =
query = "select picstr from clobtest_table where id = '001' for
pstmt = con.prepareStatement(query)
rs= pstmt.executeQuery();
oracle.sql.CLOB clobtt = ;
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== || clobtmp.length()==0){
System.out.println("======CLOB对象为空 ");
description = "";
}else{
description=clobtmp.getSubString((long)1,(int)clobtmp.length());
System.out.println("======字符串形式 "+description);
}
}