繁体   English   中英

Join 中的 Sequelize 或条件

[英]Sequelize Or condition in Join

我正在尝试使用自定义连接条件对 Sequelize ORM 进行查询。

有一个例子:

User.findAll({include: [{model: Post, where: {active: true}}]

这是连接条件的结果:

INNER JOIN `posts` AS `post` ON `users`.`id` = `post`.`user_id` AND `post`.`active`=true

我想要做的是将AND条件替换为OR并观察如下内容:

INNER JOIN `posts` AS `post` ON `users`.`id` = `post`.`user_id` OR `post`.`active`=true

我不知道是否有办法做到这一点。

您不能使用 OR 将条件添加到 JOIN 条件。 您只能添加可以使用 OR 的其他外部条件。

User.findAll({
   where: {
     [Op.or]: [
       { '$Post.somefield$': sequelize.col('some_user_field') },
       { '$Post.someotherfield$': sequelize.col('some_other_user_field') }
     ]
   },
  include: [{
    model: Post
  }
]})

这个查询在 SQL 中会是这样的:

SELECT * FROM USERS as `users`
INNER JOIN `posts` AS `post` ON `users`.`id` = `post`.`user_id`
WHERE
  `post`.`somefield`=`users`.`some_user_field`
 OR
  `post`.`someotherfield`=`users`.`some_other_user_field`

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM