繁体   English   中英

Firebase:如何在不知道其唯一ID的情况下更新记录的值项?

[英]Firebase: HowTo update the value item of a record without knowing its unique id?

因此,我的firebase结构如下:

"Posts" : {
  "0" : {
      "code": 12345TG4
      "Likes" : 59
  },
  "1" : {
      "code": RT560451
      "Likes" : 12
  }
}

理想情况下,我想做的是:

var updateData = {
  Likes: 74
}

Posts.child(id).update(updateData);

但是我不预先知道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);
    });
});

改变你的模型

尽管上面的方法可行,但您应该考虑为什么将帖子存储在数组索引下,然后它们也已经具有唯一的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);

尝试这样做。

var ref = firebase.database().ref("Posts");
ref.orderByChild("code").on("child_added", function(snapshot) {
        snapshot.ref.update(updateData);
});

最好的祝福

暂无
暂无

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

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