作者:-路人甲___ | 来源:互联网 | 2023-02-12 16:32
因此,我的firebase结构如下:
"Posts" : {
"0" : {
"code": 12345TG4
"Likes" : 59
},
"1" : {
"code": RT560451
"Likes" : 12
}
}
理想情况下,我想做的是:
var updateData = {
Likes: 74
}
Posts.child(id).update(updateData);
但是我不预先知道UiD,但是我确实有“代码”的值,它本身就是唯一的值。
如何创建查询,该查询可以基于Firebase中“代码”的已知值来更新值“喜欢”?
1> Frank van Pu..:
正如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);
});
});
改变你的模型
尽管上面的方法可行,但您应该考虑为什么将帖子存储在数组索引下,然后它们也已经具有唯一的ID。在NoSQL解决方案(例如Firebase)中,将帖子存储在代码下更为习惯:
"Posts" : {
"12345TG4" : {
"Likes" : 59
},
"RT560451" : {
"Likes" : 12
}
}
您要更新的内容:
ref.child("Posts").child("12345TG4").update({ Likes: 74 });
甚至:
"PostLikes" : {
"12345TG4" : 59,
"RT560451" : 12
}
然后:
ref.child("PostLikes/12345TG4/Likes").set(74);