gpt4 book ai didi

javascript - Knex 迁移失败并显示 - SAVEPOINT can only be used in transaction blocks

转载 作者:行者123 更新时间:2023-11-29 13:44:59 29 4
gpt4 key购买 nike

我正在尝试创建一个 knex 迁移。迁移应该是一个事务,应该向数据库添加 Angular 色和一些用户。如果用户已经在数据库中,事务应该将他们的 role_id 更改为新的 role_id

exports.up = function(knex) {
async function transaction(t) {

await t.raw('INSERT INTO "public"."role" VALUES (3, \'external_support\');');

let i;

for(i = 0; i < newUsers.length; i += 1) {

const result = await t.raw('SELECT id FROM "public"."user" WHERE email = ?;', [
newUsers[i].email
]);

if (result.rowCount === 0) {
await t.raw('INSERT INTO "public"."user" (email, first_name, last_name) VALUES (?, ?, ?);', [
newUsers[i].email,
newUsers[i].firstname,
newUsers[i].lastname
]);
await t.raw('INSERT INTO "public"."users_roles" VALUES ((SELECT id FROM "public"."user" WHERE email = ?) , 3);', [
newUsers[i].email
]);
} else {
await t.raw('UPDATE "public"."users_roles" SET role_id = 3 WHERE user_id = (SELECT id FROM "public"."user" WHERE email = ?);', [
newUsers[i].email
]);
}
}
}

所以这背后的基本逻辑是(应该是) - 添加新 Angular 色 - 检查用户是否存在 - 如果不添加用户并将其 role_id 设置为新 - 如果是,则将他们的 role_id 更改为新的

所以,我得到的是

`error: SAVEPOINT can only be used in transaction blocks`

为什么?

最佳答案

这里的问题是我没有注意documentation .我知道我看过这个,但我完全忘记了。

By default, each migration is run inside a transaction.

因此在事务中创建事务会导致挑剔的行为。在这种情况下,这是双重 promise 。

关于javascript - Knex 迁移失败并显示 - SAVEPOINT can only be used in transaction blocks,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50062144/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com