盆友们,今天我们来探讨探讨MyBatis实现一对一、一对多关联查询的方式。
就用学生和班级之间的关系来举例说明,一个学生只能有一个班级,属于一对一的关系,一个班级可以有多个学生,属于一对多的关系,当我们想要知道一个学生的班级信息或者一个班级的学生信息时,在庞杂的数据面前我们很难迅速高效的去获取到准确数据,于是乎MyBatis就给我们解决了这个问题,下面我们就一起来看看MyBatis是怎样帮助我们实现的。
首先,我们需要两张表:学生表(student)、班级表(class)
现在我们有两个需求
1、查询某个学生,包括他的班级信息
2、查询某个班级的所有学生信息
首先,创建实体类 Student 和 **Banji **
其次,创建各自的 **Mapper **接口
然后我们就可以采取两种方式去查询
第一种:**sqlMapper **配置文件
需要注意的一点是 resultMap 标签里的 id 属性必须是唯一的,即下面 select 标签里 resultMap
的值必须和 resultMap 标签里的 id 值一致。还有一点,select 标签里 id 属性的值必须和对应**Mapper **接口中对应方法的方法名一致且是唯一的。
接下来我们直接去做测试类,进行需求实现,这里我们直接来看实现效果。
查询某个学生,包括他的班级信息
** 查询某个班级的所有学生信息**
第二种:注解
该方式需要我们在** Mapper** 接口中写相对应的注解去做映射。
需求实现效果同上一种方法没有差别。
最后,对两种方法加以总结:
方式一:使用sqlMapper配置文件
一对一:在resultMap标签中使用 assocation标签
一对多:在resultMap标签中使用 collection 标签
方式二:使用注解
一对一:在 @Results 注解中的 @Result 注解中使用 @One 注解
一对多:在 @Resus 注解中的 @Result 注解中使用 @Many 注解
版权归原作者 Y_xuID 所有, 如有侵权,请联系我们删除。