Mybatis resultMap中一对多和多对一的关系

假设有两张表 一张学生表和一张教师表 表的具体结构如下:
在这里插入图片描述
学生表的tid作为外键和教师表的id进行关联 这样学生和教师之间就有了奇妙的联系了。 对于学生来说 他们和教师之间的关系应该是 多对一 的关系 多个学生对应一个教师 但是对于教师而已 他们和学生之间的关系就应该是 一对多 的关系 一个教师对应多个学生嘛 对于这两种情况 我们分别来讲解一下

多对一的关系:
我们设计实体类的时候 应该是这样设计的
学生的实体类
教师的实体类
从类的结构上来看 我们在学生的实体类中定义了一个教师的成员 这样就把学生和教师关联了起来 是一种一对多的关系 这和我们在数据库表中分析的结果是一样的 所以我们这样设计是合理的 。
那当我们通过Mybatis使用sql查询的时候 我们会得到什么结果呢 我们写一条sql语句 查询所有的学生信息

<
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MyBatis 一对多关联查询结果映射通常会采用两种方式: 1. 嵌套结果映射:使用嵌套结果映射可以将一对多关联查询的结果集映射成对象的嵌套结构。例如,假设我们有一个 User 对象和一个 Order 对象,一个用户可以拥有多个订单,我们可以通过如下方式进行嵌套结果映射: ``` <resultMap id="userResultMap" type="User"> <id column="id" property="id"/> <result column="name" property="name"/> <collection property="orders" ofType="Order"> <id column="order_id" property="id"/> <result column="order_name" property="name"/> <result column="order_amount" property="amount"/> </collection> </resultMap> ``` 上述代码,我们定义了一个名为 userResultMapresultMap,包含了 User 对象的 id 和 name,以及一个 Order 对象的集合 orders,其 Order 对象包含 id、name 和 amount 属性。在 SQL 查询,我们需要使用 LEFT JOIN 等方式将 User 和 Order 表进行关联查询,并通过 DISTINCT 或 GROUP BY 等方式去重。 2. 延迟加载:使用延迟加载可以避免在一对多关联查询时一次性加载所有的关联对象,从而提高查询性能。MyBatis 提供了两种延迟加载方式,分别是按需加载和分步加载。按需加载是指在需要使用关联对象时再进行加载,而分步加载是指在多次查询逐步加载关联对象。两种方式都需要在配置文件进行相应的配置。 总之,MyBatis一对多关联查询结果映射采用嵌套结果映射或延迟加载的方式,具体采用哪种方式取决于业务需求和性能要求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值