MyBatis 类型转换器

类型处理器(类型转换器)
1.MyBatis自带一些常见的类型处理器

int  - number


自定义MyBatis类型处理器

java -数据库(jdbc类型)

实体类Student :  boolean   stuSex      
            true:男
            false:女

表student:    number  stuSex
            1:男
            0:女

自定义类型转换器(boolean -number)步骤:

a.创建转换器:需要实现TypeHandler接口
通过阅读源码发现,此接口有一个实现类 BaseTypeHandler ,因此 要实现转换器有2种选择:
i.实现接口TypeHandler接口
ii.继承BaseTypeHandler
b.配置conf.xml
TypeHandler

public class BooleanAndIntCoverter extends BaseTypeHandler<Boolean> {
    /* 类型转换器的方向
   set: java -> db
   get db->java
   i: preparedStatement 对象的参数位置
   aBoolean:Java参数值
   jdbcType:jdbc操作数据库的值
   */
    @Override
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, Boolean aBoolean, JdbcType jdbcType) throws SQLException {
        if(aBoolean){
            preparedStatement.setInt(i,1);
        }else{
            preparedStatement.setInt(i,0);
        }
    }
    @Override
    public Boolean getNullableResult(ResultSet resultSet, String s) throws SQLException {
        return resultSet.getInt(s) == 1 ? true: false;
    }
    @Override
    public Boolean getNullableResult(ResultSet resultSet, int i) throws SQLException {
        return resultSet.getInt(i) == 1 ? true: false;
    }
    @Override
    public Boolean getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
        return callableStatement.getInt(i) == 1 ? true: false;
    }
}

配置conf.xml

<typeHandlers>
     <typeHandler handler="org.zq.coverter.BooleanAndIntCoverter"  javaType="boolean" jdbcType="INTEGER"></typeHandler>
</typeHandlers>

语句

insert into student(stuno,stuname,stuage,graname,stusex) values(#{stuNo},#{stuName},#{stuAge},#    {graName} ,#{stuSex ,javaType=boolean  ,jdbcType=INTEGER   } )

如果字段名与表明不一致 可使用resultMap惊醒·进行配置键后面的

注意#{stuNo} 中存放的是 属性值,需要严格区分大小写

发布了69 篇原创文章 · 获赞 5 · 访问量 2224

猜你喜欢

转载自blog.csdn.net/qq_42139889/article/details/103283996
今日推荐