Mybatis中resultMap标签实现多表查询(多个对象)

1 n+1

1 在teacher中添加List student,

public class Teacher {
	private int id;
	private String name;
	private List<Student> list;

2 在studentMapper.xml中添加通过tid查询

<select id="selByTid" resultType="Student" parameterType="int">
		select * from student where tid=#{0}
</select>	

3 在TeacherMapper.xml中添加查询全部

<resultMap type="Teacher" id="mymap1">		
		<id column="id" property="id"/>
		<result column="name" property="name"/>
		<collection property="list" ofType="Student" select="com.bjsxt.mapper.StudentMapper.selByTid" column="id"></collection>
</resultMap>	
<select id="selAll" resultMap="mymap1">
	select * from teacher	
</select>	

其中collection是当属性为集合类型时使用的标签

2 多表联合

<resultMap type="Teacher" id="stumap1">
		<id column="tid" property="id"/>
		<result column="tname" property="name"/>
		<collection property="list" ofType="Student">
			<id column="sid" property="id"/>
			<result column="sname" property="name"/>
			<result column="age" property="age"/>
			<result column="tid" property="tid"/>
			<association property="teacher" select="com.bjsxt.mapper.TeacherMapper.selById" column="tid"></association>
		</collection>	
	</resultMap>
	
	<select id="selAll1" resultMap="stumap1">
		select t.id tid,t.name tname,s.id sid,s.name sname,age,tid from teacher t left join student s on t.id=s.tid	
	</select>
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatisresultMap标签用于配置实体类与字段的映射规则。该标签有以下作用: - 自定义映射规则,通过id属性给映射规则指定一个唯一标识,用于在其他地方引用。 - 使用id标签配置主键映射,指定实体类的属性和数据库的字段的对应关系。 - 使用result标签配置普通字段映射,指定实体类的属性和数据库的字段的对应关系。 举例来说,可以使用resultMap标签来配置一个名为studentmap的映射规则,该规则用于将数据库的字段与Student实体类的属性进行映射。其,id标签用于配置主键映射,result标签用于配置普通字段映射。例如: ```xml <resultMap id="studentmap" type="student"> <id property="sid" column="s_id"></id> <result property="sname" column="s_name"></result> <result property="sage" column="s_age"></result> <result property="sphone" column="s_phone"></result> </resultMap> ``` 此外,在核心配置文件,还可以通过设置lazyLoadingEnabled属性来开启延迟加载。如果使用的是MyBatis 3.41之前的版本,还需要配置aggressiveLazyLoading为true。同时,可以使用resultMap标签来配置一对多的映射关系,将一个教师对象对应多个学生对象。例如: ```xml <resultMap id="teacher" type="Teacher"> <id property="tid" column="t_id"></id> <result property="tname" column="t_name"></result> <result property="tage" column="t_age"></result> <collection property="students" ofType="student"> <id property="sid" column="s_id"></id> <result property="sage" column="s_age"></result> <result property="sname" column="s_name"></result> <result property="sphone" column="s_phone"></result> </collection> </resultMap> ``` 此外,可以使用association标签来配置多对一的映射关系,将多个学生对象对应一个教师对象。例如: ```xml <association property="teacher" javaType="Teacher"> <result property="tid" column="t_id"></result> <result property="tname" column="t_name"></result> <result property="tage" column="t_age"></result> </association> ``` 总结起来,resultMap标签MyBatis用于配置实体类与字段的映射规则,可以通过id、result、collection、association等子标签实现不同类型的映射关系的配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [mybatisResultmap标签的的使用](https://blog.csdn.net/weixin_43891398/article/details/125608434)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值