Firebase - 如何在不删除整个节点的情况下从节点中删除单个数据

时间:2017-02-07 14:10:58

标签: javascript firebase firebase-realtime-database

我的数据库看起来像这样:

MYAPP
|_______________users
|                   |__OshwYF72Jhd9bUw56W7d
|                   |                   |
|                   |                   |__username
|                   |                   |__email            
|                   |                   |__blocklist             
|                   |                             |
|                   |                             |__I7Dbys9uHwbd3s4DFXo
|                   |                             |                |__blockedId:"KbHy4293dYgVtT9pdoW"
|                   |                             |                
|                   |                             |__J7c3en8rdILxJQSA9ij
|                   |                             |                |__blockedId:"Gicuwy8r23ndoijdakr"
|                   |                             |
|                   |                             |__JicbS32uf6sg28dJD2a
|                   |                             |__GidhwgcLNA8jshda2f4
|                   |
|                   |__KbHy4293dYgVtT9pdoW
|                   |__PS8tgw53SnO892Jhweh
|                   |__Gicuwy8r23ndoijdakr
|
|__conversations

我正在尝试找出正确的Firebase查询,以删除blocklist中的单个节点而不删除其他节点。

例如,我想删除等于blockedId:"KbHy4293dYgVtT9pdoW"的节点,但保留其他节点"users/"+globaluid+"/blocklist"

这是我目前正在使用的代码:

function unblockUser(){

    // friendToUnblock is the ID I want to remove from the block list:
    var friendToUnblock = document.getElementById('hiddenUid').innerHTML;

    // globaluid is the currently logged in user's ID:
    var blockedRef = firebase.database().ref('users/'+globaluid+'/blocklist/');

    var blockedQuery = blockedRef.orderByChild('blockedId').equalTo(friendToUnblock);

        blockedQuery.once('value').then(function(blockedSnapshot) {
            blockedSnapshot.ref.remove(function (error) {

                if (!error) {
                    console.log(friendToUnblock+" should now be unblocked.");
                    }else{
                        console.log("There's been an error unblocking the user: "+error);
                    }
        });
   });              

};

我认为此函数仅针对包含匹配ID的节点并将其删除,而是删除每个节点(因此删除流程中的blocklist节点)。

有没有办法定位和删除blocklist节点中包含的单个值而不删除其中包含的所有内容?

1 个答案:

答案 0 :(得分:2)

你几乎得到了它。您的查询很好,但是当您对Firebase数据库执行查询时,可能会有多个结果。因此快照包含这些结果的列表。即使只有一个结果,快照也会包含一个结果的列表。

所以你需要在回调中循环这些结果:

blockedQuery.once('value').then(function(blockedSnapshot) {
    blockedSnapshot.forEach(function(childSnapshot) {  
        childSnapshot.ref.remove(function (error) {
            if (!error) {
                console.log(friendToUnblock+" should now be unblocked.");
            }else{
                console.log("There's been an error unblocking the user: "+error);
            }
        });
    });
});