项目中使用postgresql的json类型存储了些数据。为了实现po中的类和json之间的转换,写了个通用的JSON Type Handler,分享出来。
使用jackson来实现json和object之间转换。
使用的时候在resultMap中,对应的列配置,例如:
<result column="specs" property="specs"
typeHandler="cn.devmgr.tutorial.typehandler.JsonTypeHandler" />
Mapper XML中配置的update/insert语句需要指明typeHandler
update table_xxx
set colA=#{beanA.xxx, typeHandler=cn.devmgr.tutorial.typehandler.JsonTypeHandler}
where id=xx
JsonTypeHandler.java (继承Mybatis提供的BaseTypeHandler,很简单,关键是范型的处理)
package cn.devmgr.tutorial.typehandler;
import java.io.IOException;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLExcep