MyBatis高级结果映射

        前面我们学习了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、编写测试脚本

以下是控制台输出的查询数据:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值