我正在测试Firebase的实时数据库,并且遇到了困难。首先,我想知道查找记录并使用其他信息进行更新的最佳方法是什么。假设我有一个用户,并且要发布请求,我想更改其名称。
我尝试过:
var userRef = admin.database().ref('users');
var email = req.body.email;
var name = req.body.name;
userRef.equalTo(email).update({name: name});
尝试遵循官方文档,但没有运气。
我的数据库:
users
-Lbq98URniAej2TkWBhG
email: "pepe@san.com"
name: "Pepe"
-Lbq9GC1A131De-iumI0
email: "pipa@boca.com"
name: "Pipa"
此外,请记住,我事先不了解uid,因此我必须调查子数据。
答案 0 :(得分:1)
首先,我想知道什么是找到最佳的方法 记录并使用其他信息进行更新。
我不确定这是否是最好的方法,但是对于您的情况,我会以这种方式设置数据库
users
-- unique user id - 1
-- name
-- email
-- posts
-- unique post id
-- unique user id - 2
-- name
-- email
-- posts
-- unique post id
// and so on
然后,我将使用用户ID来更改名称。
var database = admin.database();
var name = req.body.name;
var uid = req.body.uid;
var userRef = database.ref('users/' + uid);
userRef.update({name : name})
.then(() => {
console.log("Update Successfull")
})
.catch(error => {
console.log(error);
});
我猜您的数据库是以这种方式组织的:
users
-- pxTYaszxcsauniqueId1
-- email
-- name
-- posts
-- unique post id
-- abcdeFFFaKauniqueId2
-- email
-- name
-- posts
-- unique post id
// and so on
在这种情况下,我将使用电子邮件来查找文档,就像这样:
// Get a reference to the database service
var database = admin.database();
var name = req.body.name;
var email = req.body.email;
var ref = database.ref("users").orderByChild("email").equalTo(email);
ref.once("value").then(function(snapshot) {
snapshot.forEach(function(childSnapshot) {
childSnapshot.ref.update({
"name" : name
}).then(function() {
console.log("Success")
});
// Cancel enumeration
return true;
});
})
同样,这是假设您组织数据库的方式。如果您以其他方式组织数据库,则上述代码将无法正常工作。如果不同,那么请确实在发布的问题中添加组织数据库的方式。