在 MyBatis 中,可以使用 Collection 的嵌套映射技巧来处理一对多或多对多的关联关系。下面是一个示例,演示了如何使用 Collection 的嵌套映射技巧来映射一对多关系:
首先,定义两个实体类,一个是订单实体 Order,一个是订单项实体 OrderItem:
public class Order {
private Long id;
private String orderNo;
private List<OrderItem> orderItems;
// getters and setters
}
public class OrderItem {
private Long id;
private Long orderId;
private String itemName;
private Integer quantity;
// getters and setters
}
然后,在 MyBatis 的映射文件中,编写如下 SQL 查询语句,使用嵌套查询的方式实现订单和订单项的关联查询:
<select id="findOrderById" resultType="Order" parameterType="Long">
SELECT id, order_no
FROM orders
WHERE id = #{id}
</select>
<select id="findOrderItemsByOrderId" resultType="OrderItem" parameterType="Long">
SELECT id, order_id, item_name, quantity
FROM order_items
WHERE order_id = #{orderId}
</select>
最后,在 Order 的映射文件中,使用 Collection 的嵌套映射技巧将订单项关联到订单中:
<resultMap id="OrderResultMap" type="Order">
<id property="id" column="id"/>
<result property="orderNo" column="order_no"/>
<collection property="orderItems" column="id" select="findOrderItemsByOrderId"/>
</resultMap>
这样,当查询订单时,MyBatis 会自动将订单项查询出来,并映射到 Order 实体类的 orderItems 属性中,从而实现了一对多关联关系的查询和映射。