我正在使用Google Firestore。有一个名为Universities的集合,每个文档代表一所大学。
如何按名称查找大学并将其view_count更新为+1?
[Collection: Universities]:
[Document: 0JsaLtcfdDaEtHLMlMrh]:{
name: The University of Sydney,
view_count: 1
};
[Document: K2z7DMhKreyDniGUpo2t]:{
name: University of New South Wales,
view_count: 2
}
你可以这样做:
db.collection("Universities").where("name", "==", "The University of Sydney")
.get()
.then(function(querySnapshot) {
querySnapshot.forEach(function(doc) {
// doc.data() is never undefined for query doc snapshots
//console.log(doc.id, " => ", doc.data());
var docData = doc.data();
var updatedCount = docData.view_count + 1;
var universityRef = db.collection('Universities').doc(doc.id);
var setWithMerge = universityRef.set({
view_count: updatedCount
}, { merge: true });
});
})
.catch(function(error) {
console.log("Error getting documents: ", error);
});
所以,你可以做的是首先使用where
查询集合以获取具有特定名称的所有文档,然后在querySnapshot
中你将获得一个doc对象然后你可以创建该文档的引用并更新(覆盖)其view_count
属性值使用set
方法与merge: true
保持其他属性值。
关注官方文档:qazxsw poi,qazxsw poi
注意:这是一般的Web JS解决方案。您可以在角度应用程序中使用相同的逻辑和编写打字稿代码