首页 > 解决方案 > 具有动态键的嵌套对象中的 Firestore 更新字段

问题描述

我需要使用动态键更新嵌套对象中的字段。路径可能如下所示: level1.level2.DYNAMIC_KEY : updatedValue 更新方法删除 level1 上的所有其他内容,而不是仅更新嵌套对象中的字段。update() 更像是 set()。我究竟做错了什么?

我已经尝试了以下方法:

我阅读了文档https://firebase.google.com/docs/firestore/manage-data/add-data#update-data 但那样它是a)静态和b)仍然删除其他字段。

更新嵌套对象中的字段 如果您的文档包含嵌套对象,您可以在调用 update() 时使用“点表示法”来引用文档中的嵌套字段

这将是静态的并导致

update({
'level1.level2.STATIC_KEY' : 'updatedValue'
});

然后我找到了这个答案https://stackoverflow.com/a/47296152/5552695 帮助我使更新路径动态化。在此之后所需的解决方案可能看起来像

field[`level1.level2.${DYNAMIC_KEY}`] = updateValue;
update(field);

但仍然:它将删除此路径中的其他字段。

更新:

我的文档的结构如下: 快照

所以在这个结构中我只想更新 complexArray > 0 > innerObject > age

将上述路径写入 update() 方法将删除 complexArray 级别的所有其他内容。对一级字段的简单更新可以正常工作,并且不会影响其他一级字段。

是否有可能,像 update() 这样的 Firestore 函数只能作用于文档的最低字段级别。一旦我将复杂的对象放入文档中,就不可能选择这样的内部字段?我知道会有解决方案将这些“复杂”对象提取到单独的集合 + 文档中,并将它们放入我当前的最低文档级别。我认为这将是坚持 FireStore 原则的更准确的方法。但是在应用程序方面,使用复杂对象比总是深入挖掘 Firestore 集合 + 文档结构更容易。

因此,我当前的解决方案是将整个复杂对象发送到 update() 方法中,即使我只更改了应用程序端的一个字段。

标签: firebasecloudgoogle-cloud-firestore

解决方案


您是否尝试过{ merge: true }在请求中使用该选项?

db
  .collection("myCollection")
  .doc("myDoc")
  .set(
    { 
      level1: { level2: { myField: "myValue" } }
    },
    { merge: true }
  )

推荐阅读