MyBatis 类型转换器

本文介绍了MyBatis中的类型处理器,包括自带的常见类型处理器和如何自定义类型转换器,如将boolean转换为number。自定义转换器需要实现TypeHandler接口或继承BaseTypeHandler,并在conf.xml中进行配置。在处理字段名与表名不一致的情况时,可以使用resultMap配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

类型处理器(类型转换器)
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} 中存放的是 属性值,需要严格区分大小写

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值