Mybatis类型处理器

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

2.自定义MyBatis类型处理器

java <=>数据库(jdbc类型)
示例:
实体类中的Student 有成员变量 boolean stuSex true代表男 false代表女
表studen中t: number stuSex 1:男 0:女

自定义类型转换器(boolean <=>number)步骤:

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

get & set :
在这里插入图片描述

package org.lanqiao.converter;

import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;

//BaseTypeHandler<java类型>
public class BooleanAndIntConverter extends BaseTypeHandler<Boolean>{//这里要加上泛型

	
	/*
	 * 下面的参数中:
	 * ps:PreparedStatement对象
	 * i:PreparedStatement对象操作参数的位置
	 * parameter:java值
	 * jdbcType:jdbc操作的数据库类型
	 */
	 //java代码(boolean)-DB类型(number)
	@Override
	public void setNonNullParameter(PreparedStatement ps, int i, Boolean parameter, JdbcType jdbcType)
			throws SQLException {
			if(parameter) {//1
				ps.setInt(i, 1); 
			}else {//0
				ps.setInt(i, 0); 
			}
	}

	//db数据库类型(number)->java类型(boolean)
	@Override
	public Boolean getNullableResult(ResultSet rs, String columnName) throws SQLException {
		int sexNum = rs.getInt(columnName) ;//rs.getInt("stuno") ;
		return sexNum == 1?true:false ;
	}

	@Override
	public Boolean getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
		int sexNum = rs.getInt(columnIndex) ;//rs.getInt(1)
		return sexNum == 1?true:false ;
	}

	@Override
	public Boolean getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
		int sexNum = cs.getInt(columnIndex) ;//rs.getInt(1)
		return sexNum == 1?true:false ;
	}
}

可以看出来get方式重载了三种:

	//通过resultSet & 列名
	public Boolean getNullableResult(ResultSet rs, String columnName) 
	//通过resultSet & 下标
	public Boolean getNullableResult(ResultSet rs, int columnIndex) 
	//通过结果集拿
	public Boolean getNullableResult(CallableStatement cs, int columnIndex)
  1. 配置conf.xml
<typeHandlers>
		<typeHandler handler="org.lanqiao.converter.BooleanAndIntConverter" javaType="Boolean" jdbcType="INTEGER" />
	</typeHandlers>

resultMap

resultMap可以用来解决类型问题
主要有两种:

  1. 数据库类型和java中类型不同时,比如上面的boolean和false无法相互转换
  2. 比如实体类Student.java中有个字段StudentNumber,数据库中是 number,这里也是无法匹配的
    以上两种情况我们都可以使用resultMap,其他的情况(比如a.String和varchar2可以直接识别 )直接使用resultType就可以
<select id="queryStudentByStuno" 	parameterType="int"  	resultMap="studentMapping" >
		select * from student where stuno = #{stuno}
</select>
<!--注意这里的stuSex涉及到类型转换,要在大括号里写上javaType&jdbcType-->
<insert id="addStudentWithConverter" parameterType="student" >
		insert into student(stuno,stuname,stuage,graname,stusex) values(#{stuNo},#{stuName},#{stuAge},#{graName} ,#{stuSex ,javaType=boolean  ,jdbcType=INTEGER   } ) 
</insert>	
	
	<resultMap type="student" id="studentMapping">
			<!-- 分为主键id 和非主键 result-->
			<id property="id"  column="stuno"  /><!--主键用id-->
			<!--别的用property-->
			<result property="studentName"  column="name" />
			<result property="studentAge"  column="age" />
			<result property="studentName"  column="name" />
			<!--这里有类型转换,在后面加上javaType和jdbcType就可以-->
			<result property="studentSex"  column="stusex"  javaType="boolean" jdbcType="INTEGER"/>
	</resultMap>

需要注意的问题:

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

注意#{stuNo} 中存放的是 属性值,需要严格区分大小写。
focusky
commit 应用于增删改

发布了84 篇原创文章 · 获赞 9 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/Mercuriooo/article/details/103318781