我有一个集合,其文档如下所示:
count: number
first: timestamp
last: timestamp
first
值应该(几乎)在文档创建后永远不会改变。在批量写入操作中,我试图更新此集合中的文档,或创建尚不存在的那些文档。就像是
batch.setData([
"count": FieldValue.increment(someInteger),
"first": someTimestamp,
"last": someTimestamp
], forDocument: someDocumentRef, mergeFields: ["count","last"])
我的希望是通过排除
first
来自 mergeFields
数组,Firestore 将设置 count
和 last
通过将其合并到现有文档或创建一个新文档,并设置 first
仅当它没有先前的值时(即,在此操作之前该文档不存在)。现在我很清楚事实并非如此,而是 first
完全被忽略。现在我想知道 Firestore 团队针对这种情况打算做什么。我知道我可以通过事务来实现这一点,但这与我的批量写入不太相关。交易是我唯一的选择,还是有更好的方法来实现这一目标?
最佳答案
我在我的文档中创建了时间戳和其他数据,我使用单独的创建和更新函数来处理这个问题,而不是试图一次完成所有这些。
初始创建函数包括创建日期等,然后后续更新使用非破坏性更新,因此只需省略更新负载中您不想覆盖的任何字段。
例如。创造:
batch.set(docRef, {created: someTimestamp, lastUpdate: someTimestamp})
然后更新:
batch.update(docRef, {lastUpdate: someTimestamp, someOtherField: someData})
这不会覆盖 creationDate 字段或任何其他字段,但如果 someOtherField 不存在,则会创建它。
如果您需要在第一次创建文档后进行“仅更新现有字段”更新,那么目前您必须首先阅读文档以查明这些字段是否存在,然后创建一个更新有效负载来修补只有所需的字段。这可以在事务中完成,或者您可以自己编写此逻辑,具体取决于您的需要。
关于javascript - 仅当尚未设置该字段时,才在 Firestore 文档中设置该字段的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56386623/