<collection>标签用于什么查询
时间: 2023-12-02 17:03:57 浏览: 23
`<collection>`标签用于处理一对多或多对多的关联查询,它通常嵌套在`<resultMap>`标签中,用于映射关联对象的集合属性。
在一对多或多对多的关联查询中,查询结果通常是一个父对象和多个子对象的集合。例如,查询订单信息时,一个订单对应多个订单项;查询部门信息时,一个部门对应多个员工。在这种情况下,可以使用`<collection>`标签来映射子对象的集合属性。
`<collection>`标签有两种使用方式:
1. 内嵌查询:在`<collection>`标签中嵌套一个`<select>`标签,用于查询子对象的集合数据。例如:
```xml
<resultMap id="orderResultMap" type="Order">
<id property="id" column="order_id"/>
<result property="orderNo" column="order_no"/>
<collection property="orderItems" ofType="OrderItem">
<id property="id" column="item_id"/>
<result property="itemName" column="item_name"/>
<result property="itemPrice" column="item_price"/>
<select id="findOrderItemsByOrderId" parameterType="Long" resultType="OrderItem">
select * from order_item where order_id=#{orderId}
</select>
</collection>
</resultMap>
```
2. 外键关联:在`<collection>`标签中配置关联字段和主表字段,用于关联查询子对象的集合数据。例如:
```xml
<resultMap id="departmentResultMap" type="Department">
<id property="id" column="dept_id"/>
<result property="deptName" column="dept_name"/>
<collection property="employees" ofType="Employee" column="dept_id" select="findEmployeesByDeptId"/>
</resultMap>
```
在这个例子中,`<collection>`标签中的`column`属性指定了关联字段,即部门表中的`dept_id`字段,`select`属性指定了查询语句的id,即`findEmployeesByDeptId`,用于查询关联的子对象集合。在这里,`findEmployeesByDeptId`是一个独立的查询语句,用于查询指定部门下的所有员工。