Mysql Sequelize:或多个表上的条件

Mysql Sequelize:或多个表上的条件,mysql,sequelize.js,Mysql,Sequelize.js,我想用sequelizejs在多个表上添加or条件。 我的问题是,我不知道如何在多个表上使用or运算符($or和Sequelize.or) 假设我要实现以下sql查询: select * from A as a, B as b, C as c where (A.b_id = b.id and b.x = 7) or (A.c_id = C.id and c.z = "test") 我将只使用sequelize实现第一个条件,如下所示: A.findAll({ include: [{ mo

我想用sequelizejs在多个表上添加or条件。 我的问题是,我不知道如何在多个表上使用or运算符($or和Sequelize.or)

假设我要实现以下sql查询:

select * from A as a, B as b, C as c where (A.b_id = b.id and b.x = 7) or (A.c_id = C.id and c.z = "test")
我将只使用sequelize实现第一个条件,如下所示:

A.findAll({
   include: [{ model: B, where: { x: 7 } }]
})
A.findAll({
   include: [{ model: C, where: { z: "test" } }]
})
只有第二个条件是这样的:

A.findAll({
   include: [{ model: B, where: { x: 7 } }]
})
A.findAll({
   include: [{ model: C, where: { z: "test" } }]
})

但是如何将这两个查询组合成我想要的查询?

您可以这样做

A.findAll({
   include: [{model: B},{model: C}], 
   where: {
     '$or':{
        '$b.x$': 7, 
        '$c.z$': "test"
     }
   });

谢谢你的回答,很高兴听到你的回答,如果你愿意,请投票answer@SaravananNandhan:)这不起作用,因为添加多个表会导致SQL查询出现问题。我不知道确切的原因,除了当有超过1个include时joins函数如何变化。我已经尝试了不止一个表,并且收到了一个错误,即子句中缺少表名