Firestore 批处理 - 需要超过 1 次写入的操作
来源:stackoverflow
时间:2024-04-19 12:12:35 434浏览 收藏
大家好,今天本人给大家带来文章《Firestore 批处理 - 需要超过 1 次写入的操作》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!
tl;dr - 那里有一些约定/有效负载/操作,这需要进行超过 1 次批量写入。
我发现,当我将 set
操作添加到 batch
时,对于使用 firestore servertimstamp
功能的对象,它会花费 2 次写入操作,而不是 1 次。
找不到任何相关文档。
问题是,如果您在代码中使用本地计数器包装 firestore 批处理,为避免达到 500 阈值,您可能会错误计算批处理大小。
在我的示例中,我使用 golang firestore sdk(但我确实相信这个问题对于所有其他 sdk 来说都很常见,因为它源自 firestore 基本机制)
batch.Set(ctx, docRef, struct { LastUpdate time.Time `firestore:"lastUpdate,serverTimestamp"` }{}, firestore.MergeAll) --> batch.writes was increased by 2 writes rather than 1
我的问题是 - 是否有任何其他特殊的 firestore 值/操作等可能也需要进行超过 1 次批量写入操作? 还有人可以建议解决该问题的方法吗?
正确答案
所谓的字段转换操作确实可能需要在服务器上执行多个写入操作,从而减少了可以在批量写入或事务中执行的逻辑写入操作的容量。如果我没记错的话,在这种情况下,您只需为一次写入操作付费。
从我之前给what is "field transformations" in Firestore?的答案来看,可用的field transform operations似乎是setToServerValue
(您使用的服务器时间戳),increment
,appendMissingElements
,removeAllFromArray
,zqbcz qbmaximum 和 minimum
。我不确定最后两个是否已在任何 SDK 上公开。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习