mybatis实现单表多表resultMap方式

本文详细介绍了如何使用MyBatis的ResultMap实现单表和多表查询的映射关系。包括使用AutoMapping特性进行两表联合查询、通过<resultMap>标签自定义列名和属性名的映射,以及N+1方式实现关联单个对象和集合对象的查询。在实际操作中,涉及了association和collection标签的使用,并提供了相关的Mapper.xml和测试代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:方式

1业务装配:

2使用AutoMapping特性,在实现两表联合查询时通过别名完成映射

3 使用Mybatis的<resultMap>标签实现

二:resultMap标签

1 resultMap属性写在Mapper.xml中,由程序员控制查询结果和实体类的映射关系,默认mybatis使用AutoMapping特性。

2 使用<resultMap>标签时,<select>标签不写resultType属性,而是用resultMap属性引用<resultMap>标签,需要自己制定列名和属性名的对应,即使名不同也能对应,autoMapping通过表中列名和属性名相同从而自动对应

mapper.xml中:

三:resultmap实现关联单个对象(N+1方式)

1 N+1:先查询出某个表的全部信息,根据这个表的信息查询出另一个表的信息

2 与业务装配的区别:service里面写的代码,由mybatis完成

3 实现步骤:1 student类中包含一个Teacher对象  2 TeacherMapper中提供一个查询 3在StudentMapper中用association关联

4 在studentMapper中:1association装配一个对象时使用 2property:对象在类中的属性名 3select:通过哪个查询查出这个对象的信息 4column:把当前表的哪个列的值作为参数传递给另一个查询  5大前提使用N+1方式,如果列名和属性名相同,可以不配置,使用AutoMapping特性,但是MyBatis默认只会给列装配一次,column指定的列名必须在property中配置

TeacherMapper.xml:

关联一个对象,用association:

StudentMapper.xml:

Test.java测试:

运行后的查询结果中包含Teacher信息。

四:多表resultmap加载集合对象N+1方式

查询关联集合对象

一个Teacher可以包含多个student,所以一个tid可以对应多个student,但只能对应一个Teacher

Teacher.java:

studentMapper.xml:

TeacherMapper.xml:

collection标签标示属性是集合类型

test.java测试:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值