查询和更新子项内的子参数

时间:2018-05-04 20:48:30

标签: android firebase firebase-realtime-database

当前Firebase数据库结构:

Current Firebase DB Structure

我想要实现的目标:

  • 在我所有地方的任何“促销”孩子中搜索相同的优惠券。
  • 如果找到,请通过将其减少-1
  • 来更新其“限制”参数

我目前的代码:

    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下找到一个类似的例子,但我找不到我的确切案例。我真的很感谢你的帮助!

1 个答案:

答案 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,则可以显示所有拥有免费大型广告的地方。