java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > MyBatis输入映射和输出映射

MyBatis输入映射和输出映射的实现示例

作者:二哈喇子!

本文详细介绍了MyBatis框架中resultMap的使用,包括其在Java对象与数据库表列映射中的作用,以及如何配置resultMap处理不同情况,具有一定的参考价值,感兴趣的可以了解一下

前言

MyBatis的输入映射和输出映射是将Java对象和数据库表的列进行映射,实现数据的自动转换。

输入映射(Parameter Mapping):是将Java对象转换为可供SQL语句执行的参数。MyBatis提供了多种方式进行输入映射,包括基本类型、Map、注解、XML映射文件等。

输出映射(Result Mapping):是将SQL查询结果映射为Java对象。MyBatis提供了多种方式进行输出映射,包括基本类型、Map、注解、XML映射文件等。其中XML映射文件是最常用的方式,可以根据列名或列索引将查询结果映射为Java对象的属性。

通过输入映射和输出映射,可以方便地完成Java对象与数据库表的转换,提高了开发效率和代码的可维护性。

resultMap的使用

使用resultMap的场景如下:

总之,如果需要处理一些复杂的查询结果或者需要将数据库查询结果映射到Java对象中,就可以使用resultMap。

MyBatis框架的工作执行流程如下

(1)读取MyBatis配置文件mybatis-config.xml

(2)加载映射文件Mapper.xml

(3)构建会话工厂

(4)创建SqlSession对象

(5)使用Executor接口来操作数据库

(6)使用MappedStatement类型的参数对映射信息进行封装。

(7)输入参数映射

(8)输出结果映射

mapper元素子元素及其作用

在映射文件中,<mapper>元素是映射文件的根元素,其他元素都是它的子元素。这些子元素及其作用如下所示:

案例

po 类

public class Dept {
	private Integer deptno;
	private String dname;
	private String loc;
	// 自动生成两个构造方法、Getter/Setter/toString
}

在同main/java包中,新建mapper包,里面新建同名的一个接口,一个映射文件

映射文件的 namespace 是接口的限定名

只有查询语句有查询

在接口文件中:

List<Dept> queryAll();

对应的映射文件:

<mapper namespace="com.mybatis.mapper.DeptMapper">
<!-- 如果查询中的列名和某个po类的属性名不一致,那么我们就需要配置结果的映射 -->
		<!-- type:po类的名字 -->
	<resultMap type="Dept" id="dept">
		<!-- id标记配置的是主键列的映射关系 -->
		<id column="no" property="deptno" />
		<!-- result配置的是非主键列和属性的映射关系 -->
		<result column="name" property="dname"/>
		<result column="location" property="loc"/>
	</resultMap>
<!-- 如果查询语句中的列名和某个po类中的属性名一致,那么需要配置resultType -->
						    	<!-- dept:上面的id值 -->
    <select id="queryAll" resultMap="dept">
    	select deptno as no,dname as name,loc as location
    	from dept 
    </select>
</mapper>

测试代码:

@Test 
	public void queryDept() {
		DeptMapper mapper = session.getMapper(DeptMapper.class);
		List<Dept> list = mapper.queryAll();
		// foreach 生成
		for (Dept dept : list) {
			System.out.println(dept);
		}
	}

总结

如果查询语句中的列名和某个po类中的属性名一致,那么需要配置resultType

如果查询中的列名和某个 po 类的属性名不一致,那么就需要配置结果的映射

id 标记配置的是主键列的映射关系

result 配置的是非主键列和属性的映射关系

到此这篇关于MyBatis输入映射和输出映射的实现示例的文章就介绍到这了,更多相关MyBatis输入映射和输出映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文