问题
在项目上,有大文本文档,需要存入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;
}
}