gpt4 book ai didi

mysql - Sequelize 中的 findAll() 找不到在事务中创建的行

转载 作者:行者123 更新时间:2023-12-03 22:16:48 26 4
gpt4 key购买 nike

我在创建行和稍后在同一事务下选择它时遇到问题。

每当我执行以下代码时,我通常会得到一个空数组,很少会得到一个包含新创建的行的数组。

这是我运行的代码示例:

return seq.transaction((tx) => {
const options = {transaction: tx};
return model.create(user, options)
.then(() => {
return model.findAll({
include: {
all: true
}
}, options)
.then((data) => ({
console.log(data);
});
});

我在这里缺少一些基本的东西吗?谢谢!

最佳答案

我解决了这个问题。我做错的是将事务作为附加参数而不是第一个参数的 JSON 的一部分提供给 findAll() 函数。

所以代替:

return model.findAll({
include: {
all: true
}
}, options)

我应该做的:

return model.findAll({
include: {
all: true
},
transaction: options.transaction
});

希望这个解决方案对其他人有帮助。

关于mysql - Sequelize 中的 findAll() 找不到在事务中创建的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62512093/

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