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

问题描述 投票:4回答:1

当前的Firebase数据库结构:

我想要实现的目标:

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

我目前的代码:

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

android firebase firebase-realtime-database
1个回答
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,您可以显示所有拥有免费大型mac的地方。

© www.soinside.com 2019 - 2024. All rights reserved.