博为峰JavaEE技术文章 ——MyBatis Mapper TypeHandler

Mybatis的方便之处在于能够把java对象与数据库字段进行自动映射和赋值。但是有种情况是需要我们手工处理的。

比如java对象的一个字段是java.util.Date类型,但数据库是长整形(以mysqlinteger为例),mybatis在做自动转换的时候就会出现类型不匹配的错误,需要我们手工进行转换。今天小博老师就介绍一下如何进行java对象与数据库字段类型的自定义转换。

mybatis提供了对自定义的类型转换器(typeHandler)的支持,可以通过实现org.apache.ibatis.type.TypeHandler接口,也可以继承org.apache.ibatis.type.BaseTypeHandler类。今天就以继承BaseTypeHandler为例说明自定义转换器的实现方法。

第一个方法实现从java对象到数据库字段的转换,通过parameter.getTime()函数把Date对象转换成了Long类型。其他三个方法实现从数据库读取到的字符串向Date对象的转换。

完成TypeHandler后,还需要在mapper中引用。比如:在一个User类中,有一个属性updateDate是Date类型,在进行更新操作时,需要做如下定义:

updateDate=#{updateDate, typeHandler=com.bwf.tools.DateConverter}这句话明确了该类型应该是用的类型转换器。这样,我们在程序中进行日期更新时,Mybatis就会自动把User对象的updateDate日期类型属性转换成数据库字段的长整形。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容