iOS - 如何从Firebase中的多个父节点中删除子节点?

时间:2018-02-08 06:16:01

标签: ios swift firebase firebase-realtime-database swift4

我有一个应用程序,管理员会在常规用户下创建子帖子。每个用户都可以删除自己的帖子,但我想这样做,以便管理员可以删除帖子作为一种" Master Delete"。

目前,我可以从admin中删除帖子,但是当管理员删除时,它只会将其从自己的节点中删除。我确保帖子会产生一个" id"为了我自己可以使用它来比较并触发删除检查,但我没有太多运气。

我发现如果我使用这段代码:  DatabaseService.shared.REF_BASE.child("用户&#34)。子(snap.key).child("帖子&#34)。removeValue()

它将删除每个用户的所有帖子。

但是,如果我使用postID查看:DatabaseService.shared.REF_BASE.child(" users")。child(snap.key).child(" posts")。子(post.postId).setValue(无)

它将从管理员帐户中删除,但不会删除其他帐户。

我目前的代码是:

guard let uid = Auth.auth().currentUser?.uid else { return }
let post = self.posts[indexPath.row]

DatabaseService.shared.REF_BASE.child("users").observeSingleEvent(of: .value, with: { (snapshot) in
    for child in snapshot.children {
        let snap = child as! DataSnapshot

        DatabaseService.shared.REF_BASE.child("users").child(snap.key).child("posts").child(post.postId).observe(.value, with: { (snapshot) in

            if DatabaseService.shared.REF_BASE.child("users").child(snap.key).child("posts").child(post.postId).child(post.uuid).key == DatabaseService.shared.REF_BASE.child("users").child(uid).child("posts").child(post.postId).child(post.uuid).key {
                DatabaseService.shared.REF_BASE.child("users").child(snap.key).child("posts").child(post.postId).setValue(nil)
            }
        })
    }     
})

以下是我的JSON树的设置方式:

"users" : {
"fNST3lUqyzPtNqTlfCJ1BOMvBhl1" : {
  "email" : "test1@test.com",
  "first name" : "test1",
  "last name" : "test",
  "posts" : {
    "-L4noDwYVmQC7n0wVF9r" : {
      "date" : "2018-02-08 05:08:48 +0000",
      "imageURL" : "https://firebasestorage.googleapis.com/v0/b/learningfirebase-f8e28.appspot.com/o/postImages%2F6EAEA5E2-A687-4FC5-9234-929D4019A74F.jpg?alt=media&token=4cff25fa-9290-4e06-97cf-abf4d6c126bc",
      "isPending" : "false",
      "pair" : "",
      "price" : "",
      "signal" : "BUY",
      "uuid" : "-L4noDwPcvqjxTgDMzRl"
    },

有什么建议吗?我已经挣扎了好几个小时,我似乎无法弄清楚这里出了什么问题。

2 个答案:

答案 0 :(得分:0)

var old_Child = d.removeChild(to_BeRemoved);


// nested>

while (element.firstChild) {

element.removeChild(element.firstChild);
}

答案 1 :(得分:0)

我刚刚解决了这个问题。我将离开解决方案,以防其它人帮助。

就我而言,我需要改变将数据添加到数据库的方式。最初,我正在使用:

DatabaseService.shared.REF_BASE.child("users").child(snap.key).child("posts").childByAutoId.setValue(parameters)

问题在于Firebase无法迭代并在删除时识别帖子ID。所以我改成了这个:

DatabaseService.shared.REF_BASE.child("users").child(snap.key).child("posts").child(key).setValue(parameters)

“key”的值是:

let key = DatabaseService.shared.REF_BASE.child("users").child(snapshot.key).child("posts").childByAutoId().key

这样做是在将值添加到数据库时为每个帖子提供相同的Id。然后我们可以在删除时将其与ID匹配。我上面发布的相同删除代码适用于我想要做的事情。

如果不清楚,请告诉我。