[英]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.