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