簡體   English   中英

Sequelize:或多個表的條件

[英]Sequelize: Or-condition over multiple tables

我想用sequelizejs在多個表上添加一個或條件。 我的問題是我不知道如何在多個表上使用或運算符($或和Sequelize.or)。

假設我想實現以下sql-query:

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},{model: C}], 
   where: {
     '$or':{
        '$b.x$': 7, 
        '$c.z$': "test"
     }
   });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM