问题描述
前端展示地图需要存入一个大的json 到oracle 数据库,数据类型只能使用clob,但是我对这个类型使用比较陌生,实体中直接定义clob类型返回错误。
尝试解决方案:
1.网上查的使用to_char 将clob 转化为string,会报长度超出4000,不可行。
2.还有一个常见的方案说是返回CLOB 然后java内存中转化为String,这个我尝试也是查询报错。不知道咋回事。
最后实现方案:
实体定义:字段还是定义成String类型
Mapper.xml 中增加映射:
<result property="configValue" column="config_value" javaType="java.lang.String" jdbcType="CLOB" typeHandler="org.apache.ibatis.type.ClobTypeHandler"/>
sql 不改,该怎么查怎么查 select config_vlaue from test
可以实现大json字符串的正常返回
解决OracleCLOB存储JSON并用MyBatis返回的问题
在前端展示地图时遇到问题,需将大型JSON存入Oracle数据库的CLOB字段。尝试将CLOB转为String失败,因长度超限。最终通过在实体中保持String类型,Mapper.xml中使用ClobTypeHandler进行映射,成功实现了从CLOB字段查询并返回大JSON字符串。
4751

被折叠的 条评论
为什么被折叠?



