当前的Firebase数据库结构:
我想要实现的目标:
我目前的代码:
mDatabase = FirebaseDatabase.getInstance().getReference("Place");
Query query = mDatabase.child("promotions").orderByChild("coupon").equalTo("FREEBIGMAC");
query.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for (DataSnapshot snapshot: dataSnapshot.getChildren()) {
// Not able to find anything here
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
System.out.println("The read failed: " + databaseError.getMessage());
}
});
我一直试图在StackOverFlow下找到一个类似的例子,但我找不到我的确切案例。我将衷心感谢您的帮助!
Firebase数据库只能查询执行查询的位置的每个子节点下的已知路径的属性。它无法处理动态路径,正如您在此处所做的那样。
有关这方面的更长解释,请参阅我的答案:Firebase Query Double Nested。这似乎也很相关:Firebase query if child of child contains a value。
解决方案是对数据进行非规范化处理,并取消这些地方的促销活动。如果您有一个促销列表,您可以获得所有拥有免费大型mac的人:
mDatabase = FirebaseDatabase.getInstance().getReference("Promotions");
Query query = mDatabase.orderByChild("coupon").equalTo("FREEBIGMAC");
query.addListenerForSingleValueEvent(new ValueEventListener() {
现在,如果您为每个促销添加Place
,您可以显示所有拥有免费大型mac的地方。