【发布时间】:2021-03-27 00:57:44
【问题描述】:
我正在尝试在 MySQL 表中插入多条记录,但无论我做什么,它都只插入一行。
这里是 node.js 代码:
let orderID = 15; //It is a foreign key. Noted it from the table.
itemParams = [
[ orderID, 'd', 34.6, '12', '123.jpeg' ],
[ orderID, 'd', 30.6, '2', '456.jpeg' ]
];
let addOrderItems = await pool.query(`INSERT INTO orderitems (oid, description, weight, quantity, image_url) VALUES (?)`, itemParams);
当我在控制台记录 addOrderItems 时,affectedRows 计数为 1,因此我还在 Workbench 中检查了我的表以确保只添加了一行。 (oid 是外键)。表确实有一个自动递增的主键。
我在网上找到的查询在问号周围没有括号?但是当我删除括号时,我收到以下错误:
Error: ER_PARSE_ERROR: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '19, 'd', 34.6, '12', '123.jpeg'' at line 1
at Query.Sequence._packetToError (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\sequences\Sequence.js:47:14)
at Query.ErrorPacket (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\sequences\Query.js:79:18)
at Protocol._parsePacket (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\Protocol.js:291:23)
at Parser._parsePacket (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\Parser.js:433:10)
at Parser.write (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\Parser.js:43:10)
at Protocol.write (Z:\Jura_SaaS\node_modules\mysql\lib\protocol\Protocol.js:38:16)
at Socket.<anonymous> (Z:\Jura_SaaS\node_modules\mysql\lib\Connection.js:88:28)
at Socket.<anonymous> (Z:\Jura_SaaS\node_modules\mysql\lib\Connection.js:526:10)
at Socket.emit (events.js:315:20)
at addChunk (_stream_readable.js:309:12)
--------------------
at Pool.query (Z:\Jura_SaaS\node_modules\mysql\lib\Pool.js:199:23)
at internal/util.js:297:30
at new Promise (<anonymous>)
at Pool.query (internal/util.js:296:12)
at Z:\Jura_SaaS\routes\order.js:190:44
at processTicksAndRejections (internal/process/task_queues.js:93:5) {
code: 'ER_PARSE_ERROR',
errno: 1064,
sqlMessage: "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '19, 'd', 34.6, '12', '123.jpeg'' at line 1",
sqlState: '42000',
index: 0,
sql: "INSERT INTO orderitems (oid, description, weight, quantity, image_url) VALUES 19, 'd', 34.6, '12', '123.jpeg';"
}
注意:我已经承诺 pool.query 这就是你看不到它的回调格式的原因。
【问题讨论】:
-
请注意
mysql是一个较旧的 npm 包。使用mysql2。你可以参考这个链接,我以前解决过。 stackoverflow.com/questions/64464555/… -
首先,您可能需要考虑将
values(?)更改为values(?,?....) -
好的,我先试试mysql2,但是插入数组的时候只打一个问号
-
为什么会这样?我试过用一个问号,我也有类似的问题
-
在插入一个元组/行时添加多个问号(与字段一样多)。如果要插入多个元组,您将提供一个列表列表,因此列表将与问号相关而不是列表中的项目,这是我经过反复试验得出的结论
标签: mysql node.js sql-insert mysql-error-1064