ResultMap中association和collection的区别

mybatis mapper配置文件结果集映射resultMap中collection属性(一对多关系结果集映射)和association属性(多对一关系结果集映射)理解:
collection的使用有两种resultMap和select,必须手动指定一种
association的使用和collection使用类似,只是right join需换成left join
rd_one属性时用association标签, 映射card_many时用collection标签.
所以association是用于一对一和多对一,而collection是用于一对多的关系
下面就用一些例子解释下吧
association-一对一
人和身份证的关系
下面是pojo

public class Card implements Serializable{
    private Integer id; private String code;//省略set和get方法.}public class Card implements Serializable{
   
 private Integer id;
 private String code;
//省略set和get方法.
}
public class Person implements Serializable{
    private Integer id; private String name; private String sex; private Integer age; //人和身份证是一对一的关系 private Card card;//省略set/get方法.}public class Person implements Serializable{
   
 private Integer id;
 private String name;
 private String sex;
 private Integer age;
 //人和身份证是一对一的关系
 private Card card;
//省略set/get方法.
}

下面是mapper和实现的接口

package com.glj.mapper; import com.glj.poji.Card; public interface CardMapper {
    Card selectCardById(Integer id);}package com.glj.mapper;

import com.glj.poji.Card;

public interface CardMapper {
   
 Card selectCardById(Integer id);
}

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.glj.mapper.CardMapper"> <select id="selectCardById" parameterType="int" resultType="com.glj.poji.Card"> select * from tb_card where id = #{
   id}  </select></mapper><?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.glj.mapper.CardMapper">
 <select id="selectCardById" parameterType="int" resultType="com.glj.poji.Card">
 select * from tb_card where id = #{
   id} 
 </select>
</mapper>?1234567package com.glj.mapper;  import com.glj.poji.Person;  public interface PersonMapper {
    Person selectPersonById(Integer id);}package com.glj.mapper;
 
import com.glj.poji.Person;
 
public interface PersonMapper {
   
 Person selectPersonById(Integer id);
}?12345678910111213141516171819<?xml version="1.0" encoding="UTF-8"
  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis Plus的AssociationCollection都是用于多表关联查询的。其Association用于一对一的关系,Collection用于一对多的关系。 下面是一个Association的例子: 假设我们有两个表,一个是学校表(school),另一个是班级表(class)。一个学校可以有多个班级,但一个班级只属于一个学校。我们需要查询学校信息,并且将学校下的所有班级信息也一并查询出来。 ```java public class School { private Long id; private String name; private List<Class> classes; // getter and setter } public class Class { private Long id; private String name; private Long schoolId; // getter and setter } ``` 对应的Mapper.xml文件如下: ```xml <select id="getSchoolById" resultMap="schoolResultMap"> select * from school where id = #{id} </select> <resultMap id="schoolResultMap" type="School"> <id property="id" column="id"/> <result property="name" column="name"/> <collection property="classes" ofType="Class"> <id property="id" column="id"/> <result property="name" column="name"/> <association property="school" javaType="School"> <id property="id" column="school_id"/> <result property="name" column="school_name"/> </association> </collection> </resultMap> ``` 上述代码,我们使用了collection标签来表示一对多的关系,使用了association标签来表示一对一的关系。其,association标签的javaType属性表示关联的实体类类型,id标签的column属性表示关联的字段名。 下面是一个Collection的例子: 假设我们有两个表,一个是班级表(class),另一个是学生表(student)。一个班级可以有多个学生,我们需要查询班级信息,并且将班级下的所有学生信息也一并查询出来。 ```java public class Class { private Long id; private String name; private List<Student> students; // getter and setter } public class Student { private Long id; private String name; private Long classId; // getter and setter } ``` 对应的Mapper.xml文件如下: ```xml <select id="getClassById" resultMap="classResultMap"> select * from class where id = #{id} </select> <resultMap id="classResultMap" type="Class"> <id property="id" column="id"/> <result property="name" column="name"/> <collection property="students" ofType="Student"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="classId" column="class_id"/> </collection> </resultMap> ``` 上述代码,我们同样使用了collection标签来表示一对多的关系。注意,由于Student实体类已经有了classId属性,因此我们不需要再使用association标签来表示一对一的关系。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值