有些时候,java代码的类型和数据库jdbc的类型不一致时,需要自定义类型转换器,让mybatis能够识别。
比如java代码中boolean类型,存储到数据库中时用number类型。(true--1,false--0)
此时就需要我们创建类型转换器。创建方式有两种,一种是实现TypeHandler接口,还有一种是继承BaseTypeHandler实现类。观察源码发现,baseTypeHandler是TypeHandler的实现类,所以我们使用继承BaseTypeHandler的方式实现起来更方便.
自定义一个类,BooleanAndIntConverter,重写4个方法,1个set,3个get,同时继承BaseTypeHandler时,存在泛型约束,可以指定需要转换的java类型Boolean。
其中setNonNullParameter表示将java的类型,set成数据库jdbc类型,而三个get方法则相反,表示从数据库中获取jdbc类型的数据,转换成java类型。set方法中4个参数分别表示:PreparedStatement对象,操作对象参数的位置,java类型(这里是Boolean类型),jdbc操作数据库类型。
@Override
public Boolean getNullableResult(ResultSet rs, String columnName) throws SQLException {
&nb