阅读量:0
在 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 属性中,从而实现了一对多关联关系的查询和映射。