DynamoDB 单表设计:如何获取某个类型的所有实体

Mar*_*arc 2 amazon-web-services nosql amazon-dynamodb

我正在为我的应用程序中的相关实体创建单表 DynamoDB 设计。我主要从这里借用了一些想法:https : //github.com/aws-samples/amazon-dynamodb-design-patterns/blob/master/data-models/an-online-shop/AnOnlineShop.md

虽然大多数事情对我来说都很清楚,但对我来说却缺少一件简单的事情。如何查询某种类型的所有实体?有关架构,请参见下图。

在此处输入图片说明

如您所见,主要实体记录的 PK 和 SK 具有相同的值。SK 仅在您希望与其他实体具有 1:N 关系时才会更改,如 entityType 仓库项中所示。

我的主要问题是:如何获得所有用户(当然无需扫描即可快速获得)?

我学到的是,我不能在 PartitionKey 上执行 begin_with。当然,我可以考虑做这样的记录:

PK       SK
users   u#logemann
users   u#smith
Run Code Online (Sandbox Code Playgroud)

但这将需要额外的数据条目,并且会与我上面看到的主要用户记录重复。或者是否可以创建一个 GSI,其 PK 值为“users”,SK 值为 SK?

解决这个问题的最佳方法是什么?

Mar*_*arc 6

我认为最简单的方法是在 GSI 中添加“EntityType”作为 PartitionKey 和“PK”作为 SortKey。通过这种方式,我可以以一种高性能的方式查询我的所有实体。

  • @SethGeoghegan 如果您有一个大型数据集,这不会是一个潜在的问题吗?因为 GSI 在单个分区键中可能会包含大量文档?编辑:例如,在OPs问题中“user”是一种类型,如果有10万个用户,那么“user”GSI分区键可能会非常大?或者这不是一个问题? (3认同)