如何使用 node.js 从 mySQL 中的数组插入多条记录
How do I insert multiple records from array in mySQL using node.js
我查了一下table:
CREATE TABLE technologies (
technologyName VARCHAR(50) NOT NULL PRIMARY KEY
);
我想在此 table 中为数组中的每个元素存储一条新记录:
var values = ['Grunt', 'Gulp'];
所以结果 table 看起来像:
+----------------+
| technologyName |
+----------------+
| Grunt |
+----------------+
| Gulp |
+----------------+
如何使用 Node 执行此操作?
更新:
我知道我可以做这样的事情:
var values = [
[
['Grunt'],
['Something']
]
]
connection.query('INSERT IGNORE INTO technologies (technologyName) VALUES ?', values);
我用原始数组试过了,但它不起作用。如何将简单数组转换为更复杂的数组?
您可以一次插入多个内容...
来自 mysql 文档 (https://dev.mysql.com/doc/refman/5.5/en/insert.html)
INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);
所以对你来说:
insert into technologies (technologyname) values ('grunt'),('gulp')
var sql = "insert into technologies (technologyname) values ";
for(var v in values)
sql += "('" + connection.escape(values[v]) + "'),";
sql = sql.substr(0,sql.length-1); // take off the last comma since we added one after each value
如果你想使用“?”为了转义您的值并避免 SQL 注入,mysqljs 接受嵌套数组以进行批量插入。
所以你更新的答案是:
var valuesNestedArray = [];
for(var v in values ) {
valuesNestedArray.push([values[v]]);
}
var sql = "INSERT IGNORE INTO technologies (technologyname) values ?";
connection.query(sql, [valuesNestedArray], function(err) {
if (err) throw err;
});
我查了一下table:
CREATE TABLE technologies (
technologyName VARCHAR(50) NOT NULL PRIMARY KEY
);
我想在此 table 中为数组中的每个元素存储一条新记录:
var values = ['Grunt', 'Gulp'];
所以结果 table 看起来像:
+----------------+
| technologyName |
+----------------+
| Grunt |
+----------------+
| Gulp |
+----------------+
如何使用 Node 执行此操作?
更新:
我知道我可以做这样的事情:
var values = [
[
['Grunt'],
['Something']
]
]
connection.query('INSERT IGNORE INTO technologies (technologyName) VALUES ?', values);
我用原始数组试过了,但它不起作用。如何将简单数组转换为更复杂的数组?
您可以一次插入多个内容...
来自 mysql 文档 (https://dev.mysql.com/doc/refman/5.5/en/insert.html)
INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);
所以对你来说:
insert into technologies (technologyname) values ('grunt'),('gulp')
var sql = "insert into technologies (technologyname) values ";
for(var v in values)
sql += "('" + connection.escape(values[v]) + "'),";
sql = sql.substr(0,sql.length-1); // take off the last comma since we added one after each value
如果你想使用“?”为了转义您的值并避免 SQL 注入,mysqljs 接受嵌套数组以进行批量插入。 所以你更新的答案是:
var valuesNestedArray = [];
for(var v in values ) {
valuesNestedArray.push([values[v]]);
}
var sql = "INSERT IGNORE INTO technologies (technologyname) values ?";
connection.query(sql, [valuesNestedArray], function(err) {
if (err) throw err;
});