mybatis中一对多查询collection关联不执行

本文介绍了在MyBatis中遇到的一对多查询关联未执行的问题,原因是缺少主键id,导致查询条件缺失。通过检查并确保传递id字段,可以解决这个问题。
摘要由CSDN通过智能技术生成

 今天遇到的原因是因为下面红底id没有,导致关联查询没有条件(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.***.abc.dao.CompanyMapper" >
  <resultMap id="BaseResultMap" type="com.***.abc.bean.Company" >
    <id column="id" property="id" jdbcType="BIGINT" />
    <result column="company_name" property="companyName" jdbcType="VARCHAR" />
//一个公司包含多个员工,根据公司id可以查出一个公司 所有员工,一对多的关系。
<collection property="empList" fetchType="lazy" ofType="com.***.abc.bean.Emp" column=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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> ``` 上述代码,我们定义了一个名为 userResultMap 的 resultMap,包含了 User 对象的 id 和 name,以及一个 Order 对象的集合 orders,其 Order 对象包含 id、name 和 amount 属性。在 SQL 查询,我们需要使用 LEFT JOIN 等方式将 User 和 Order 表进行关联查询,并通过 DISTINCT 或 GROUP BY 等方式去重。 2. 延迟加载:使用延迟加载可以避免在一对多关联查询时一次性加载所有的关联对象,从而提高查询性能。MyBatis 提供了两种延迟加载方式,分别是按需加载和分步加载。按需加载是指在需要使用关联对象时再进行加载,而分步加载是指在多次查询逐步加载关联对象。两种方式都需要在配置文件进行相应的配置。 总之,MyBatis一对多关联查询结果映射采用嵌套结果映射或延迟加载的方式,具体采用哪种方式取决于业务需求和性能要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值