node-mysql 慢速插入多个查询

node-mysql slow insert with multiple queries

我是 node-mysql 的新手,但我遇到了一个令人担忧的速度问题,因为它非常简单。 我正在处理相当合理数量的数据(2000 mysql 条目)并且当我使用多个查询时通过 connection.query() 输入它变得非常慢。代码是这样的

var rows = xlsx.rows;
for (var i=0; i<rows.length; ++i) {
    var escaped = '';
    var values = [];
    var row = rows[i];
    escaped += 'INSERT INTO Main (name, value, enabled) VALUES ';

    var name = row['name'];
    var val = row['value'];
    var enabled = rows['enabled'];

    escaped += '(?,?,?);';
    values.push(name);
    values.push(val);
    values.push(enabled);

    connection.query(escaped, values);
}

输入所有行需要一分钟以上的时间。当我在一个查询中使用多个语句时,出现了同样的问题。我唯一能够快速且几乎立即输入所有行的情况是,如果我使用一个字符串和一个条目,a.k.a。

INSERT INTO Main (name, value, enabled) VALUES (?,?,?), (?,?,?), (?,?,?)...

我是否只是以低效的方式使用查询?还是此处的查询速度存在实际问题?

如评论中所述,这只是一种插入mysql数据的缓慢方式,使用起来更容易

connection.query('INSERT INTO Table (col1, col2) VALUES ?', [insert], callback);

其中 insert 是包含多个条目值的变量