The*_*eoG 0 javascript firebase reactjs firebase-realtime-database
因此,我的firebase结构如下:
"Posts" : {
"0" : {
"code": 12345TG4
"Likes" : 59
},
"1" : {
"code": RT560451
"Likes" : 12
}
}
Run Code Online (Sandbox Code Playgroud)
理想情况下,我想做的是:
var updateData = {
Likes: 74
}
Posts.child(id).update(updateData);
Run Code Online (Sandbox Code Playgroud)
但是我不预先知道UiD,但是我确实有“代码”的值,它本身就是唯一的值。
如何创建查询,该查询可以基于Firebase中“代码”的已知值来更新值“喜欢”?
正如Doug所评论和Rodrigo所展示的那样,您必须先根据商品代码查询商品,然后才能对其进行更新:
var ref = firebase.database().ref();
ref.child("Posts").orderByChild("code").equalTo("12345TG4").once("value", function(snapshot) {
snapshot.forEach(function(child) {
child.ref.update(updateData);
});
});
Run Code Online (Sandbox Code Playgroud)
尽管上面的方法可行,但您应该考虑为什么将帖子存储在数组索引下,然后它们也已经具有唯一的ID。在NoSQL解决方案(例如Firebase)中,将帖子存储在代码下更为习惯:
"Posts" : {
"12345TG4" : {
"Likes" : 59
},
"RT560451" : {
"Likes" : 12
}
}
Run Code Online (Sandbox Code Playgroud)
您要更新的内容:
ref.child("Posts").child("12345TG4").update({ Likes: 74 });
Run Code Online (Sandbox Code Playgroud)
甚至:
"PostLikes" : {
"12345TG4" : 59,
"RT560451" : 12
}
Run Code Online (Sandbox Code Playgroud)
然后:
ref.child("PostLikes/12345TG4/Likes").set(74);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1795 次 |
| 最近记录: |