簡體   English   中英

如何在 knex.js 遷移中鏈接承諾

[英]How to chain promises inside a knex.js migration

session-pg-simple 需要創建一個表來存儲會話,我想將此表添加到我的 knex.js 遷移腳本中。

CREATE TABLE "session" (
  "sid" varchar NOT NULL COLLATE "default",
    "sess" json NOT NULL,
    "expire" timestamp(6) NOT NULL
)
WITH (OIDS=FALSE);

ALTER TABLE "session" ADD CONSTRAINT "session_pkey" PRIMARY KEY ("sid") NOT DEFERRABLE INITIALLY IMMEDIATE;

CREATE INDEX "IDX_session_expire" ON "session" ("expire");

以上是來自https://github.com/voxpelli/node-connect-pg-simple/blob/HEAD/table.sql的表創建腳本

exports.up = function (knex) {
  return Promise.all([
    knex.schema
      .createTable("session", function (table) {
        table.text("sid").notNullable().collate("default");
        table.json("sess").notNullable();
        table.timestamp("expire", { precision: 6 }).notNullable();
      })
      .then(
        knex.schema.raw(
          'ALTER TABLE "session" ADD CONSTRAINT "session_pkey" PRIMARY KEY ("sid") NOT DEFERRABLE INITIALLY IMMEDIATE;'
        )
      )
      .then(
        knex.schema.raw(
          'CREATE INDEX "IDX_session_expire" ON "session" ("expire");'
        )
      ),

    knex.schema.createTable("users", function (table) {
       //...
    }),
  ]);
};

初始表創建后的 2 .thens 不運行,我嘗試在 Promise.all([]) 的末尾添加它們,但它也不起作用。 如何在我的腳本中實現這兩行?

Promise.all不需要那里,並且您錯過了then塊中的return語句。 無論如何,您的代碼可以大大簡化,knex 支持鏈接,這意味着您可以創建一個接一個調用的方法鏈:

exports.up = function (knex) {
  return knex.schema
    .createTable("session", function (table) {
      table.text("sid").notNullable().collate("default");
      table.json("sess").notNullable();
      table.timestamp("expire", { precision: 6 }).notNullable();
    })
    .raw(
      'ALTER TABLE "session" ADD CONSTRAINT "session_pkey" PRIMARY KEY ("sid") NOT DEFERRABLE INITIALLY IMMEDIATE;'
    )
    .raw(
      'CREATE INDEX "IDX_session_expire" ON "session" ("expire");'
    )
    .createTable("users", function (table) {
       //...
    })
};

使用此代碼,您無需更改表或在raw創建索引:

exports.up = knex => {
    return Promise.all([
        knex.schema.createTable('session', function (table) {
            table.string('sid').primary().notNullable();
            table.json('sess').notNullable();
            table.timestamp('expire', { precision: 6 }).notNullable();
        })
    ]);
};

exports.down = knex => {
    return Promise.all([knex.schema.dropTableIfExists('sessions')
    ]);
};

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM