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日期类型属性转换成数据库字段的长整形。