mybatis多表关联插入怎么写
时间: 2024-03-21 14:30:01 浏览: 53
关于你的问题,我可以回答:在 MyBatis 中,多表关联插入一般使用 XML 映射文件进行配置,下面是示例代码:
<insert id="insertOrder" parameterType="Order">
INSERT INTO orders (order_id, user_id, status)
VALUES (#{orderId}, #{userId}, #{status})
</insert>
<insert id="insertOrderItem" parameterType="OrderItem">
INSERT INTO order_items (order_id, product_id, quantity)
VALUES (#{orderId}, #{productId}, #{quantity})
</insert>
<select id="selectOrderById" resultType="Order">
SELECT * FROM orders WHERE order_id = #{orderId}
</select>
<select id="selectOrderItemsByOrderId" resultType="OrderItem">
SELECT * FROM order_items WHERE order_id = #{orderId}
</select>
在以上示例中,insertOrder 和 insertOrderItem 分别表示插入订单和订单项的 SQL 。要在多表插入中使用这些语句,可以在 Java 代码中使用两个方法插入 order 和 order_item ,如下所示:
public void insertOrderAndItems(Order order, List<OrderItem> items) {
orderMapper.insertOrder(order);
for (OrderItem item : items) {
item.setOrderId(order.getOrderId());
orderItemMapper.insertOrderItem(item);
}
}
下面的示例代码显示了如何使用 select 语句查询 order 和 order_item :
public Order selectOrderById(int orderId) {
Order order = orderMapper.selectOrderById(orderId);
if (order != null) {
List<OrderItem> items = orderItemMapper.selectOrderItemsByOrderId(orderId);
order.setOrderItems(items);
}
return order;
}
以上就是在 MyBatis 中实现多表关联插入的详细步骤。
阅读全文