gpt4 book ai didi

node.js - Sequelize - 使用 or 运算符和模型关联查询

转载 作者:行者123 更新时间:2023-12-03 22:38:24 31 4
gpt4 key购买 nike

使用 Sequelize,我有两个具有 多对多 关联的模型: UserCategory
我想获得属于当前用户的所有类别,以及具有特定属性的类别,但我不明白如何,只有一个查询......

根据 documentation 和关联模型的 Op.or 语法(见 here ),我正在使用 $Model.attribute$ 运算符。

let categories = await models.category.findAll({
where: {
[Op.or]: [
{ someCategoryProperty: true },
{ '$User.id$': req.currentUser.id },
],
},
include: [{
model: models.user,
as: 'User',
}],
});

如果我添加关于 Category 模型的 2 个条件,则运算符会起作用,但是如何在关联上添加条件?

最佳答案

我终于找到了提示:

实际上,$Model.attribute$ 不是好的模式,$database_table_name.attribute$ 是好的模式。

对于 '$..$' 语法,我们必须使用 数据库表名 ,而不是模型。
如果我的模型名为 user ,Sequelize 设置数据库名称 users !

所以这段代码有效:

let categories = await models.category.findAll({
where: {
[Op.or]: [
{ someCategoryProperty: true },
{ '$users.id$': req.currentUser.id },
],
},
include: [{
model: models.user,
}],
});

谢谢

关于node.js - Sequelize - 使用 or 运算符和模型关联查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54774258/

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