一个奇怪的问题oracle大字段操作clob.getCharacterStream()访问出现连接关闭错误-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

一个奇怪的问题oracle大字段操作clob.getCharacterStream()访问出现连接关闭错误

2016-03-19 10:22:38 6184 1

处理clob字段的时候,出现这么一个错误,当直接使用

private T01_organService getOrganService(){
return (T01_organService) SpringContextUtil.getBean("t01_organService");
}

访问clob.getCharacterStream()就会出现“连接已经关闭”的错误,但是在db2下没有这个问题。

另外后来修改了,用配置的方式,然后再service中声明

public IAlarmMessageDao alarmMessageDao;

的方式,就没有这个错误。

取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 19:07:32

    估计是你的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;
        }

    这段代码可以的。亲测

    0 0
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 1039219浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157697浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 337014浏览量 回答数 8

3

回答

请问postgres实时同步数据到mysql数据库有什么好的方案吗?

toni3 2019-06-29 14:55:43 116156浏览量 回答数 3

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 128883浏览量 回答数 2

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 259837浏览量 回答数 38

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 305632浏览量 回答数 249

97

回答

Redhat/CentOS一键安装web环境全攻略

xiaofanqie 2011-08-11 14:51:38 123703浏览量 回答数 97

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 204392浏览量 回答数 2

11

回答

【精品问答合集】MongoDB热门问答

李博 bluemind 2019-05-29 16:50:19 121329浏览量 回答数 11
+关注
0
文章
14879
问答
问答排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载