批量增加这样写有错误吗 <insert id="addBatchOrder"> insert into `order`(id, status, payment, create_time, address, create_user_id, commodity_id) values <foreach collection="orderList" item="order" separator="," open="" close=";"> #{order} </foreach> </insert>
时间: 2024-03-25 19:35:58 浏览: 99
MYSQL 小技巧 -- LAST_INSERT_ID
这段代码存在问题,主要是在`foreach`标签中`#{order}`不能直接作为插入语句的参数,需要将`#{order}`中的属性和字段明确指定,例如:
```
<insert id="addBatchOrder">
insert into `order`(id, status, payment, create_time, address, create_user_id, commodity_id) values
<foreach collection="orderList" item="order" separator="," open="" close="">
(#{order.id}, #{order.status}, #{order.payment}, #{order.createTime}, #{order.address}, #{order.createUserId}, #{order.commodityId})
</foreach>
</insert>
```
在插入语句中,将对象的属性和表中的字段一一对应。这样才能正确地将对象插入到数据库中。另外,注意表名`order`是 MySQL 的关键字,需要使用反引号将其括起来。
阅读全文