firebase查询在第二/第三级

时间:2016-07-30 18:12:59

标签: javascript firebase firebase-realtime-database

我在Firebase上使用Javascript,我想对第二级或第三级存在的值进行查询,我的DB就是这样:

Users :
        -KNwBd5cF6iY9dWh0eFd :
                name: "Jon Snow"
                phones:
                    phone1: "0123456789"
                    phone2: "0123456987"

我想对phone1值进行查询,我现在使用orderByChild来查询数据库,我的代码是:

var ref = firebase.database().ref("users");
ref.orderByChild("name").equalTo("Jon Snow").on("value", function(snapshot) {
    console.log(snapshot.val());
});

但我只能用它来查询第一级值的值,但是如何在第二级或第三级进行另一次查询。

1 个答案:

答案 0 :(得分:2)

不知道手机ID并考虑到您当前的数据库结构,这是不可能的。

一种解决方法是使用实​​际的电话号码作为/phones中的密钥。

{ 
  users:
    userId:
       phones:
          0123456789: true
}

然后您将能够通过以下方式检索它:

ref.orderByChild("phones/"+phoneNumber).equalTo(true).once("value", function(snapshot) {
    console.log(snapshot.val());
});

工作jsFiddle

如果您拥有phoneId,这将很简单。

ref.orderByChild("phones/phone1").equalTo("0123456789").once("value", function(snapshot) {
    console.log(snapshot.val());
});

既然你没有,它就会成为你不应该如何构建noSQL数据库的一个很好的例子。

noSQL数据库非常灵活,其结构很大程度上取决于您的应用程序。所以记住它。例如,如果在您的应用程序中搜索phoneNumber将是至关重要的,并且您希望在/phones/phoneNumber/中包含更多数据,那么您应该考虑使用新的单独分支来以比您更专注的方式处理此问题现在正在做