mybatis一对多查询实现association
时间: 2023-08-09 15:11:48 浏览: 93
Mybatis中可以通过association标签实现一对多查询。association标签用于处理一对一关系,而collection标签用于处理一对多关系。在一对多查询中,通常会在主表中包含一个外键,该外键指向从表中的主键。
下面是一个简单的示例,假设我们有两个表Order和OrderItem,Order表中包含一个外键指向OrderItem表的主键,代码如下:
```
<resultMap id="orderMap" type="Order">
<id property="orderId" column="order_id" />
<result property="orderName" column="order_name" />
<association property="orderItem" resultMap="orderItemMap" />
</resultMap>
<resultMap id="orderItemMap" type="OrderItem">
<id property="orderItemId" column="order_item_id" />
<result property="orderItemName" column="order_item_name" />
</resultMap>
<select id="selectOrder" resultMap="orderMap">
select *
from order o
left join order_item oi on o.order_id = oi.order_id
where o.order_id = #{orderId}
</select>
```
在上面的示例中,我们定义了两个resultMap,一个用于映射Order表,另一个用于映射OrderItem表。在Order表的resultMap中,我们使用了association标签来处理一对多关系,将Order表中的orderItem属性映射到OrderItem表中,通过resultMap属性指定了OrderItem表的resultMap。
在select语句中,我们通过left join关键字将Order表和OrderItem表关联起来,通过where条件指定了查询的订单ID。最终返回的结果将会是一个Order对象,其中包含一个List<OrderItem>类型的orderItem属性,该属性中包含了该订单对应的所有订单项。
阅读全文