所以我正在寻找相当于WHERE IN(val1,val2)
我试过这样但是不起作用。
Angular Firebase
this.firebase.database.list('/favorites', {
query: {
orderByChild: 'uID',
equalTo: [1,2,3,'some value]
}
});
Firebase的查询没有OR
或IN
运算符。因此,您无法轻松将上述查询映射到Firebase。
一种解决方法是在元素上实现multiFilter:
public items: FirebaseListObservable<any[]> = null;
ngOnInit() {
this.items = this.db.list('/favorites', {
query: {
orderByChild: 'uID'
}
});
this.items.subscribe(items => {
console.info(this.multiFilter(items,{'uID': [1,2,3,'some value]}));
});
}
public multiFilter(arr: Object[], filters: Object) {
const filterKeys = Object.keys(filters);
return arr.filter(eachObj => {
return filterKeys.every(eachKey => {
if (!filters[eachKey].length) {
return true; // passing an empty filter means that filter is ignored.
}
return filters[eachKey].includes(eachObj[eachKey]);
});
});
};
我会让用户在用户节点下。
通常,ID将是firebase pushKeys。
所以user> userId> {user information}。
然后有企业
business> businessId> {business information}
然后是企业到用户节点。
businessForUser> userId> businessId = true
因此,您将从businessForUser节点获取该用户的businessID列表,然后使用这些获取的ID从业务节点获取业务信息。
通过在firebase.database.Reference上构建来创建查询。检查Doc:https://github.com/angular/angularfire2/blob/master/docs/rtdb/querying-lists.md
this.firebase.database.list('/favorites', {
ref => ref.orderByChild('uID').equalTo(1,2,3,'some value)
});
要么
constructorpublic af:AngularFireDatabase) {
this.items = af.list('/messages', ref =>
ref.orderByKey(true).equalTo(1,2,3,'some value));
});