我的数据库看起来像这样:
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
节点中包含的单个值而不删除其中包含的所有内容?
答案 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);
}
});
});
});