书架和where / orwhere语法问题

问题描述

await bookshelf
    .model('User')
    .where({ org_id: this.get('id'),isAdministrator: 1 })
    .fetchAll()
    .then...

这有效并选择具有特定org_idisAdministrator等于1的那些记录。

我想以此方式扩展.where行,以便它也选择合伙人和合伙人。我希望他能执行以下代码

await bookshelf
    .model('User')
    .query({
        where: { org_id: this.get('id'),isAdministrator: 1 },orWhere: { org_id: this.get('id'),isAssociate: 1 },isPartner: 1 }
    })
    .fetchAll()
    .then...

但是,它仅选择管理员和合作伙伴,而不选择同事。我在做什么错了?

解决方法

问题是.query函数的参数是

{
        where: { org_id: this.get('id'),isAdministrator: 1 },orWhere: { org_id: this.get('id'),isAssociate: 1 },isPartner: 1 }
}

无效,因为javascript对象不能具有多个相同的键。改为:

bookshelf.model('User').query((queryBuilder) => {
    queryBuilder
        .where({ org_id: this.get('id'),isAdministrator: 1 })
        .orWhere({ org_id: this.get('id'),isPartner: 1 })
        .orWhere({ org_id: this.get('id'),isAssociate: 1 });
    }).fetchAll({debug: true}).then(function(users){
        //...
})