当前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下找到一个类似的例子,但我找不到我的确切案例。我真的很感谢你的帮助!
答案 0 :(得分:2)
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
,则可以显示所有拥有免费大型广告的地方。