mybatis plus一对多

文章展示了如何在Java中使用XML配置进行一对多的结果映射。第一个示例是将Teacher类的students属性映射为Student对象的列表,而第二个示例则将学生ID映射为字符串列表。这两个例子都涉及到数据库查询结果到Java对象的转换。

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

一对多结果映射(xml)
样例1:list 对象类型

public class Teacher{
    private String tname;
    private String tage;
    private List<Student> students;
}

xml:

  <resultMap id="testMap" type="org.example.controller.Teacher">
    <result property="tname" column="name"></result>
    <result property="tage" column="name"></result>
    <collection property="students" ofType="org.example.controller.Student">
      <result property="" column=""></result>  
      <result property="" column=""></result>
      <result property="" column=""></result>
    </collection>
  </resultMap>

样例1:list String类型

public class Teacher {
    private String tname;
    private String tage;
    //private List<Student> students;
    private List<String> studentIds;
}
  <resultMap id="testMap" type="org.example.controller.Teacher">
    <result property="tname" column="name"></result>
    <result property="tage" column="name"></result>
    <collection property="students" ofType="org.example.controller.Student">
      <result column="student_id"></result>
    </collection>
  </resultMap>
### MyBatis Plus 实现一对查询 在MyBatis Plus中实现一对查询相对简便,主要依赖于`@TableField`注解以及自定义SQL语句或使用内置方法完成复杂的数据映射。对于实体类的设计,在某些情况下可能需要额外字段用于存储关联对象及其列表形式的结果集。 #### 定义实体类结构 为了表示一对的关系,可以在父级实体内声明子项集合属性,并标记这些属性不存在于数据库表中: ```java @Entity @Data public class Order implements Serializable { private static final long serialVersionUID = 1L; @Id private Long id; // ... other fields ... @TableField(exist = false) private List<Item> items; } ``` 此部分展示了如何设置一个订单(Order)与个商品(Item)之间的关系[^4]。 #### 创建Mapper接口 接着创建对应的Mapper接口继承BaseMapper<T>, 并可以在此基础上扩展特定业务逻辑的方法签名: ```java public interface UserMapper extends BaseMapper<User> { /** * 自定义的一对查询方法. */ List<UserWithOrdersDTO> selectUsersWithOrders(); } ``` 上述代码片段说明了怎样通过定义新的方法来进行更复杂的查询操作[^2]. #### 处理分页问题 当涉及到分页时需要注意的是,默认情况下MyBatis Plus可能会返回不准确的总数(total),这是因为内部处理机制所致。解决这一现象的一个常见方案是在collection标签处应用子查询方式来获取正确的记录数量[^3]: ```xml <resultMap type="com.example.UserWithOrdersDTO"> <!-- 用户基本信息 --> <id column="userId" property="id"/> ... <!-- 订单详情 --> <collection property="orders" ofType="com.example.Order" select="selectOrderItemsByUserId" column="{ userId=id }"/> </resultMap> <select id="selectOrderItemsByUserId" resultType="com.example.OrderItem"> SELECT * FROM order_item oi WHERE oi.user_id = #{userId,jdbcType=BIGINT} </select> ``` 这段XML配置指出了如何调整映射规则以确保分页统计准确性[^5].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值