小编Aar*_*shi的帖子

如何使用 Knex.js 将 1000 万行插入 MySQL 数据库?

我正在尝试使用 Knex.js 将 10M+ 行插入 MySQL 数据库。有没有办法使用 for 循环插入长度为 10000 的数组(这似乎是我能够插入的最大大小 - 任何大于该值的数组都会出现“错误:ER_NET_PACKET_TOO_LARGE:得到的数据包大于'max_allowed_pa​​cket'字节”)。

我尝试使用承诺链,但该链对于容纳 10M 条记录来说会很长。

exports.seed = (knex) => {
  // Deletes ALL existing entries
  return knex('books').del()
    .then(() => {
      const fakeBooks = [];
      for (let i = 0; i < 10000; i += 1) {
        fakeBooks.push(createFakeBooks());
      }
      return knex('books').insert(fakeBooks)
        .then(() => {
          const fakeBooks1 = [];
          for (let i = 0; i < 10000; i += 1) {
            fakeBooks1.push(createFakeBooks());
          }
          return knex('books').insert(fakeBooks1)
            .then(() => {
              const fakeBooks2 = …
Run Code Online (Sandbox Code Playgroud)

javascript mysql node.js knex.js

4
推荐指数
1
解决办法
4894
查看次数

标签 统计

javascript ×1

knex.js ×1

mysql ×1

node.js ×1