如何解决书架和where / orwhere语法问题
await bookshelf
.model('User')
.where({ org_id: this.get('id'),isAdministrator: 1 })
.fetchAll()
.then...
这有效并选择具有特定org_id
且isAdministrator
等于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){
//...
})
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。