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

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

比如java对象的一个字段是java.util.Date类型,但数据库是长整形(以mysql integer为例),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日期类型属性转换成数据库字段的长整形。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值