MyBatis如何实现多表查询(一对一、一对多)

        盆友们,今天我们来探讨探讨MyBatis实现一对一、一对多关联查询的方式。

        就用学生和班级之间的关系来举例说明,一个学生只能有一个班级,属于一对一的关系,一个班级可以有多个学生,属于一对多的关系,当我们想要知道一个学生的班级信息或者一个班级的学生信息时,在庞杂的数据面前我们很难迅速高效的去获取到准确数据,于是乎MyBatis就给我们解决了这个问题,下面我们就一起来看看MyBatis是怎样帮助我们实现的。

首先,我们需要两张表:学生表(student)、班级表(class)

现在我们有两个需求

1、查询某个学生,包括他的班级信息

2、查询某个班级的所有学生信息

首先,创建实体类 StudentBanji 

 

 

其次,创建各自的 Mapper 接口

 

 

然后我们就可以采取两种方式去查询

第一种:sqlMapper 配置文件

需要注意的一点是 resultMap 标签里的 id 属性必须是唯一的,即下面 select 标签里 resultMap

的值必须和 resultMap 标签里的 id 值一致。还有一点,select 标签里 id 属性的值必须和对应Mapper 接口中对应方法的方法名一致且是唯一的。

 接下来我们直接去做测试类,进行需求实现,这里我们直接来看实现效果。

查询某个学生,包括他的班级信息

 查询某个班级的所有学生信息

 第二种:注解

该方式需要我们在 Mapper 接口中写相对应的注解去做映射

 需求实现效果同上一种方法没有差别。

最后,对两种方法加以总结:

方式一:使用sqlMapper配置文件

                一对一:在resultMap标签中使用 assocation标签

                一对多:在resultMap标签中使用 collection 标签

方式二:使用注解

                一对一:在 @Results 注解中的 @Result 注解中使用 @One 注解

                一对多:在 @Resus 注解中的 @Result 注解中使用 @Many 注解

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值