在MyBatis中,可以使用嵌套查询或者嵌套结果映射来实现一对多数据的查询和封装。
首先,在mapper文件中定义查询一的一方的SQL语句,使用嵌套查询查询多的一方的数据。例如:
<select id="getOrderById" resultType="Order">
SELECT * FROM orders WHERE id = #{id}
</select>
然后,在mapper文件中定义查询多的一方的SQL语句,使用嵌套查询查询多的一方的数据。例如:
<select id="getOrderItemsByOrderId" resultType="OrderItem">
SELECT * FROM order_items WHERE order_id = #{orderId}
</select>
最后,在mapper文件中使用association和collection标签进行嵌套查询和封装。例如:
<select id="getOrderWithItemsById" resultType="Order">
SELECT * FROM orders WHERE id = #{id}
</select>
<resultMap id="OrderWithItemsResultMap" type="Order">
<association property="orderItems" javaType="java.util.List" column="id" select="getOrderItemsByOrderId"/>
</resultMap>
首先,在mapper文件中定义查询一的一方的SQL语句,使用嵌套结果映射查询多的一方的数据。例如:
<select id="getOrderById" resultMap="OrderWithItemsResultMap">
SELECT * FROM orders WHERE id = #{id}
</select>
然后,在mapper文件中定义查询多的一方的SQL语句,使用嵌套结果映射查询多的一方的数据。例如:
<select id="getOrderItemsByOrderId" resultMap="OrderItemResultMap">
SELECT * FROM order_items WHERE order_id = #{orderId}
</select>
最后,在mapper文件中使用association和collection标签进行嵌套结果映射和封装。例如:
<resultMap id="OrderWithItemsResultMap" type="Order">
<collection property="orderItems" javaType="java.util.List" resultMap="OrderItemResultMap"/>
</resultMap>
以上是两种常用的方式来实现MyBatis的一对多数据查询和封装,具体使用哪种方式可以根据具体情况来选择。