我正在使用Firebase,我想按quoteID排序结果。但是,orderbychild并未按预期返回列表中的第一项或最后一项。
this.props.firebase.db.ref('quotes').orderByChild("quoteId").limitToFirst(1).once("value", snapshot => {
const entry = snapshot.val();
console.log(entry);
})
我的数据结构如下:
{
"1ec658d2-a7cb-45b8-8d9b-9c2a6783365d" : {
"dateCreated" : "2019-12-02T16:06:50+01:00",
"owner" : "DVRVSpeOXQV6wAmHAdpAe6iPQ5i2",
"quoteID" : "200115001",
"timeStamp" : 2075985276
},
"3e95a6ba-df85-4dbb-97b0-cf36df068bc1" : {
"dateCreated" : "2019-09-27T09:17:58+02:00",
"owner" : "xZBFCq4ho3V2G8dZTvK7RjsnTr43",
"quoteID" : "200115002",
"timeStamp" : 1
},
"d95d1f32-804b-4625-8f7e-e0bfb4f032e6" : {
"dateCreated" : "2019-12-10T14:39:40+01:00",
"projectName" : "testPropject timestamp2",
"quoteID" : "191210000",
"timeStamp" : 1575985180
}
}
我获得带有qouteID'200115001'的条目作为第一个单项返回。我不明白为什么不首先按照文档中的描述按字典顺序返回“ 191210000”
https://firebase.google.com/docs/database/web/lists-of-data#data-order
答案 0 :(得分:0)
从Firebase获得的快照包含每个匹配子节点的3条信息:
调用snapshot.val()
时,此数据将转换为简单的JSON对象。在该对象中,只有两条信息可以存放:密钥和值。 JSON对象中的键顺序是不确定的,因此当您调用snapshot.val()
时,结果的顺序会丢失。
要维持顺序,请使用snapshot.forEach()
遍历子节点。像这样:
this.props.firebase.db.ref('quotes').orderByChild("quoteId").limitToFirst(1).once("value", snapshot => {
snapshot.forEach((child) => {
console.log(child.key);
console.log(child.val());
})
})