Angular2Firebase通过多个值whereIN查询

问题描述 投票:5回答:3

所以我正在寻找相当于WHERE IN(val1,val2)我试过这样但是不起作用。

Angular Firebase

this.firebase.database.list('/favorites', {
            query: {
                orderByChild: 'uID',
                equalTo: [1,2,3,'some value]
            }
});
angular firebase ionic-framework
3个回答
2
投票

Firebase的查询没有ORIN运算符。因此,您无法轻松将上述查询映射到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]);
    });
  });
};

1
投票

我会让用户在用户节点下。

通常,ID将是firebase pushKeys。

所以user> userId> {user information}。

然后有企业

business> businessId> {business information}

然后是企业到用户节点。

businessForUser> userId> businessId = true

因此,您将从businessForUser节点获取该用户的businessID列表,然后使用这些获取的ID从业务节点获取业务信息。


1
投票

通过在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));
        });
© www.soinside.com 2019 - 2024. All rights reserved.