Java读取Oracle的Clob类型数据,由Clob转String

目录

转化方法一(不推荐):拼接数据流

转化方法二(推荐):getSubString


问题场景:

        从Oracle读取出来的字段是Clob类型数据,因需要对其进行操作,则转成字符串类型

调用方法:

Clob clobDDL = (Clob) map.get("ClobDDL");
String str = ClobToString(clobDDL);

转化方法:

转化方法一(不推荐):拼接数据流

  可以通过stream流将clob字段,拼接起来,这样对于一些简单的数据是没有问题的,但是有时候会碰到clob字段的数据,带一些特殊字符,比如换行、空格等格式的话,解析出来的数据是不带空格和换行的,那这样的数据就是有问题的,和原来的不符合

 /**
     * clob转String
     *
     * @param clob
     * @return
     */
    public String ClobToString(Clob clob) {
        String reString = "";
        try {
            Reader is = clob.getCharacterStream();// 得到流
            BufferedReader br = new BufferedReader(is);
            String s = br.readLine();
            StringBuffer sb = new StringBuffer();
            while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING
                sb.append(s);
                s = br.readLine();
            }
            reString = sb.toString();
        } catch (Exception e) {
            log.error("Oracle数据由Clob类型转化String类型处理失败 原因={}", e.getMessage());
            throw new BizException("Oracle数据处理失败");
        }
        return reString;
    }

转化方法二(推荐):getSubString

可以直接通过clob的提供的方法进行处理,非常的方便,但是一定要注意判空,通过下面的这种方式处理,即使有换行、空格等特殊字符出现的时候,都能够原模原样的保存到新的字段当中

比如判空处理:

/**
     * clob转String
     *
     * @param clob
     * @return
     */
    public String ClobToString(Clob clob) {
        String reString = "";
        try {
            reString = clob.getSubString((long) 1, (int) clob.length());
        } catch (Exception e) {
            log.error("Oracle数据由Clob类型转化String类型处理失败 原因={}", e.getMessage());
            throw new BizException("Oracle数据处理失败");
        }
        return reString;
    }