前面我们学习了MyBatis的基本用法,主要是针对单表进行的增上改查操作(上一篇文章链接MyBatis映射文件-CSDN博客)。在实际开发中,对数据库的操作常常会涉及到多张表,针对多表之间的操作,MyBatis提供了关联映射和集合映射,通过它们可以很好地处理表与表、对象与对象之间的数据映射关系。
关系型数据库表之间关系:
一对一:一个表中的一条记录最多可以与另一个表中的一条记录相关。
一对多:主表中的一条记录可以和另外一个表的多条记录相关,但另外一个表中的记录只能与主表中的某一条记录相关
多对多:一个表中的一条记录可以与另外一个表任意数量的记录相关,另外一个表中的一条记录也可以与本表中任意数量的记录相关。
一、关联映射
数据关系:在Java语言中描述数据之间的关系(一对一、一对多、多对多),其实就是使对象的属性与另一个对象的属性相互关联。
例子:在ssm数据库中,有用户基本信息表(usr_base)和用户详细信息表(usr_profile),表结构如下所示:
要求:查询所有的用户信息,结果包含每位用户的基本和详细信息。
方案一:表连接查询
(1)初始化数据表
(2)创建实体类
(3)创建名为UsrBaseMapper.xml和UsrProfileMapper.xml的映射文件
(4)编写测试脚本
方案二:嵌套查询
步骤:在方案一的基础上进行修改
(1)修改UsrBaseMapper.xml
(2)修改UsrProfileMapper.xml
(3)编写测试脚本
二、集合映射
以下面这个问题为例,我们来学习集合映射。
1、搭建数据库表
方案一:表连接查询
1、编写实体类
2、编写SysUserMapper.xml映射文件
3、编写SysDeptMapper.xml映射文件
4、编写测试脚本
以下是控制台输出的查询数据:
方案二:嵌套查询
嵌套查询可以在方案一的基础上进行修改,以下是以方案一为基础进行修改的步骤。
1、查询语句
2、修改SysUserMapper.xml映射文件
3、修改SysDeptMapper.xml映射文件
4、编写测试脚本
以下是控制台输出的查询数据: