开发一个查询功能时,遇到了一个ORM的问题:数据库字段是 Blob 类型,里面实际存储的是文本数据,Java 后端代码中用字符串 String 类型去接收这个字段的数据时,报错,提示没有对应的setter方法,类型不匹配;换成 byte[] 字节数组类型去接收这个字段的数据,依然报错,同样是找不到setter方法,类型不匹配;最后只好将Java中对应的变量类型改为 java.sql.Blob 类型去接收对应的数据,不报错了,但如何取获取其中的文本数据呢?
使用的代码如下:
privateString getTextFromBlob(Blob blob) {int i = 1;byte btArr[] = new byte[0];try{while (i
btArr=ArrayUtils.addAll(btArr, bytes);
i+= 1024;
}return new String(btArr, "GB2312");
}catch(Exception e) {
logger.error(e.getMessage(), e);return null;
}
}
代码逻辑并不复杂,但其实这地方有一个坑,需要注意一下。
最开始的时候写的代码并不是这样,我在 while 循环里每次拿 1024 个字节的数据,然后使用 new String(bytes,"GB2312") 得到字符串,再用 StringBuilder 把每次循环得到的字符串拼接起来,最后 stringBuilder.toString() 返回完整的字符