处理clob字段的时候,出现这么一个错误,当直接使用
private T01_organService getOrganService(){
return (T01_organService) SpringContextUtil.getBean("t01_organService");
}
访问clob.getCharacterStream()就会出现“连接已经关闭”的错误,但是在db2下没有这个问题。
另外后来修改了,用配置的方式,然后再service中声明
public IAlarmMessageDao alarmMessageDao;
的方式,就没有这个错误。
估计是你的Clob包引用有问题。
public static String getCreateTabelSQL(String tableName, String owner) throws Exception{
final StringBuffer FIND_CREATE_TABLE_SQL = new StringBuffer();
FIND_CREATE_TABLE_SQL.append("Select Dbms_Metadata.Get_Ddl('TABLE', '");
FIND_CREATE_TABLE_SQL.append(tableName);
FIND_CREATE_TABLE_SQL.append("', '");
FIND_CREATE_TABLE_SQL.append(owner);
FIND_CREATE_TABLE_SQL.append("') From Dual");
ResultSet rs = null;
oracle.sql.CLOB clob = null;
java.sql.PreparedStatement pstmt = dbUtil.getConnection().prepareStatement(FIND_CREATE_TABLE_SQL.toString());
rs= pstmt.executeQuery();
if(rs.next()){
//rs.getClob(1)中参数1指的是HCONTENT字段索引,第一个字段从1开始而不是从0。
//也可以用字段名来取rs.getClob("HCONTENT")
clob = (oracle.sql.CLOB)rs.getClob(1);
}
return ClobToString(clob);
}
public static String ClobToString(oracle.sql.CLOB clob) {
String reString = "";
StringBuffer sb;
try {
Reader is = clob.getCharacterStream();// 得到流
BufferedReader br = new BufferedReader(is);
String s = br.readLine();
sb = new StringBuffer();
while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING
sb.append(s);
s = br.readLine();
}
reString = sb.toString();
System.out.println(reString);
} catch (Exception e) {
e.printStackTrace();
}
return reString;
}
这段代码可以的。亲测
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。