在Cloud Firestore中有三种写操作:
add () 设置() update ()
在文档中,它说使用set(object, {merge: true})将把给定的对象与现有的文档合并。
当你使用update(object)…那么有什么不同呢?谷歌会像这样复制功能,这似乎很奇怪。
在Cloud Firestore中有三种写操作:
add () 设置() update ()
在文档中,它说使用set(object, {merge: true})将把给定的对象与现有的文档合并。
当你使用update(object)…那么有什么不同呢?谷歌会像这样复制功能,这似乎很奇怪。
当前回答
“用合并设置”和“更新”之间的另一个区别(扩展Scarygami的回答)是在处理嵌套值时。
如果你的文档结构是这样的:
{
"friends": {
"friend-uid-1": true,
"friend-uid-2": true,
}
}
并且想要添加{"friend-uid-3": true}
用这个:
db.collection(“用户”). doc(随机身份)这里({ “朋友”:{ “friend-uid-3”:真的 } },{合并:真})
将得到以下数据:
{
"friends": {
"friend-uid-1": true,
"friend-uid-2": true,
"friend-uid-3": true
}
}
但是使用这个更新:
db.collection(“用户”). doc(随机身份).update ({ “朋友”:{ “friend-uid-3”:真的 } })
将得到以下数据:
`{
"friends": {
"friend-uid-3": true
}
}`
其他回答
用于docs: https://firebase.google.com/docs/firestore/manage-data/add-data#update_fields_in_nested_objects
点表示法允许您更新单个嵌套字段,而无需覆盖其他嵌套字段。如果更新一个没有点表示法的嵌套字段,则将覆盖整个map字段。
如上所述,这将取代整个好友结构。
db.collection('users').doc('random-id').update({
"friends": {
"friend-uid-3": true
}
})
但这不是。
db.collection('users').doc('random-id').update({
"friends.friend-uid-3": true
})
“用合并设置”和“更新”之间的另一个区别(扩展Scarygami的回答)是在处理嵌套值时。
如果你的文档结构是这样的:
{
"friends": {
"friend-uid-1": true,
"friend-uid-2": true,
}
}
并且想要添加{"friend-uid-3": true}
用这个:
db.collection(“用户”). doc(随机身份)这里({ “朋友”:{ “friend-uid-3”:真的 } },{合并:真})
将得到以下数据:
{
"friends": {
"friend-uid-1": true,
"friend-uid-2": true,
"friend-uid-3": true
}
}
但是使用这个更新:
db.collection(“用户”). doc(随机身份).update ({ “朋友”:{ “friend-uid-3”:真的 } })
将得到以下数据:
`{
"friends": {
"friend-uid-3": true
}
}`
进一步补充上述答案,如果您想删除映射中的嵌套字段,那么您可能需要使用update或set,这取决于您的用例。
如果您从以下开始,并希望删除除“user1”之外的所有配置文件条目,那么您有两个选项。
{
"users": {
"profiles": {
"user1": ...,
"user2": ...
}
}
更新
这将使用所提供的内容覆盖概要文件
update({
'users.profiles': { 'user1': ... }
})
Set
这将把删除的内容合并到现有的配置文件中, 留下未删除的内容
set({
users: {
profiles: {
'user2': FieldValue.delete(),
'user3': FieldValue.delete(),
...
}
}
}, { merge: true })
这只适用于map,因为set和update都会覆盖数组,除非显式地使用特定于数组的操作符,比如arrayUnion。
Scarygami的答案也适用于firebase版本9。但是应该考虑一些小的改变:
使用setDoc而不是set。例如,不要使用db.collection('users').doc('random-id')。集({“admin”:真});使用setDoc (doc (db,“用户的随机身份),{“admin”:真}) 使用updateDoc而不是update。例如,不要使用db.collection('users').doc(random-id')。update({"age": 27}),使用await updateDoc(doc(db, 'users', 'random-id'), {"age": 27})
关于批处理还有一个有趣的行为:
如果至少有一个文档不存在,则批量更新将失败。
批处理设置{merge: true}将成功更新所有现有文档,并为不存在的文档创建新文档。