繁体   English   中英

在Firebase查询中组合orderByChild和equalTo

[英]Combining orderByChild and equalTo in Firebase queries

鉴于以下数据结构:

{
  "comments" : {
    "-JcBbk64Gpm1SKoFHv8b" : {
      "content" : "blah",
      "createdAt" : 1417550954985,
      "link" : "http%3A%2F%2Flocalhost%3A3000%2F",
      "recommendedCount" : 0,
      "replies" : {
        "-JcBbk8gF_nQ_vjwag61" : true
      },
      "replyCount" : 1
    },
    "-JcBbk8gF_nQ_vjwag61" : {
      "content" : "blah blah",
      "createdAt" : 1417550955151,
      "link" : "http%3A%2F%2Flocalhost%3A3000%2F",
      "recommendedCount" : 0,
      "replyCount" : 1,
      "replyToComment" : "-JcBbk64Gpm1SKoFHv8b"
    }
  },
  "links" : {
    "http%3A%2F%2Flocalhost%3A3000%2F" : {
      "author" : 5,
      "commentCount" : 2,
      "comments" : {
        "-JcBbk64Gpm1SKoFHv8b" : true,
        "-JcBbk8gF_nQ_vjwag61" : true
      },
      "createdAt" : 1417550954931,
      "ratingCount" : 2,
      "recommendedCount" : 32,
      "score" : 91,
      "title" : "A Christian vs. an Atheist: Round 2",
      "url" : "http://localhost:3000/"
    }
  }
}

我想检索给定链接的所有注释,并按相反的时间顺序对它们进行排序。 我已经做到了这一点,但我无法弄清楚如何进行反向排序,因为我已经使用orderByChild通过链接缩小结果范围:

ref.orderByChild('link').equalTo(currentLink).on('value', function (snap) {
  console.log(snapshot.val());
});

如果我第二次这样调用orderByChild():

ref.orderByChild('link').equalTo(currentLink).orderByChild('createdAt').on('value', function (snap) {
  console.log(snapshot.val());
});

它失败并显示以下错误消息:

未捕获的错误:Query.orderByChild:您无法组合多个orderBy调用。

我很难过。 有什么建议?

我在firebase项目中遇到了同样的问题,我解决了这个问题。 请看一下。

var formRef = firebase.child('links').child(currentLink);
formRef.orderByChild('createdAt').on('value', function (snap) {
  console.log(snapshot.val());
});

它会奏效。 最好的祝福。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM