用hibernate SQLquery读取CLOB数据

在直接用hibernate native sql查询数据库的时候,发现有个字段是CLOB。
在显示声明返回字段类型的时候,本来是写sq.addScalar("fd_vehicle_no1", Hibernate.CLOB);
后来发现http://topic.csdn.net/u/20100831/16/66c692fd-bc53-4aba-9f29-953a5e58bdb8.html里面有人提到了
Hibernate映射成text类型
读进去的时候用流,取出来的时候直接*.getXXX();就行;

试了一下,果然可以。。

如果是原方案的话,还需要如下java代码转换类型
public String ClobToString(CLOB clob) throws SQLException, IOException {

String reString = "";

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();

return reString;

}


你可能感兴趣的:(Hibernate)