gpt4 book ai didi

google-app-engine - Google 应用引擎实体组

转载 作者:太空宇宙 更新时间:2023-11-03 15:19:29 24 4
gpt4 key购买 nike

据我从 App Engine 教程中了解到,实体组的存在只是为了交易目的:

“仅在交易需要时才使用实体组”(来自教程)

同一个实体组的定义就是同根。那么,多于1个层级有什么用呢?也就是说,为什么我要使用“A -> B -> C”(A 是根,B 他的儿子,C 他的孙子)而不是“A -> B ; A -> C”? (A、B 和 C 仍然在同一个实体组中,因为 A 是它们的根)。

如果实体组的唯一目的是使实体之间的交易成为可能,为什么我应该使用超过 1 个层次结构级别(我从 Root -> Grandson 链接中获得什么)?

最佳答案

当你进行查询时,你可以使用ancestor()将查询限制为特定实体的子代 - 在您的示例中,您可以仅查找 B 的后代,如果它们都在顶层,您将无法执行此操作。

Programming Google App Engine 中有更多关于祖先查询的信息

Keys and Entity Groups医生还说:

Entity group relationships tell App Engine to store several entities in the same part of the distributed network ... All entities in a group are stored in the same datastore node

编辑:同一文档还列出了一些您不希望您的实体组变得太大的原因:

The more entity groups your application has—that is, the more root entities there are—the more efficiently the datastore can distribute the entity groups across datastore nodes. Better distribution improves the performance of creating and updating data. Also, multiple users attempting to update entities in the same entity group at the same time will cause some users to retry their transactions, possibly causing some to fail to commit changes. Do not put all of the application's entities under one root.

组中实体的任何事务都会导致对同一实体组的任何其他写入失败。如果您有一个包含大量写入的大型实体组,这会导致大量争用,然后您的应用程序必须处理预期的写入失败。 Avoiding datastore contention详细介绍了可以用来减少争用的策略。

关于google-app-engine - Google 应用引擎实体组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2002887/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com