Clob 字段转String

问题

在项目上,有大文本文档,需要存入clob 字段,如何取出clob 字段来? 应用的Mybatis框架

解决思路

第一: 若是能保证数据量小于4000的话, to_char(clob字段)  是一个非常简单省事的方案;

第二:若是字段长度不能固定,肯定有大于4000 的数据量,这个时候,可以写一个实类,然后 string 字段,然后get set操作;默认生成就可以;【也可以解决问题】;

第三: 就是需要写一个类,专门去做clob 转字符串处理;【这里着重讲解这个】

解决方案一

/**
 * @Description OracleClob2String
 */
@Slf4j
public class OracleClob2String {
    public static String ClobToString(Clob clob)  {
        String reString = "";
        try {
            Reader is = null;// 得到流
            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 + "\n");
                s = br.readLine();
            }
            reString = sb.toString();
        } catch (Exception e) {
            log.error("解析错误,错误消息={}", e.getMessage());
        }
        return reString;
    }

}

解决方案二

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不努力谁会可怜你?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值