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惊醒·进行配置键后面的
mybatis输入/输出参数详解+动态sql:https://blog.csdn.net/getchar97/article/details/95381629

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值