作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为我的应用程序中的相关实体创建单表 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
但这需要额外的数据条目,并且会与上面看到的我的主要用户记录有些重复。或者是否可以创建一个 GSI,PK 为“用户”,SK 为 SK?
解决这个问题的最佳方法是什么?
最佳答案
我认为最简单的方法是在 GSI 中添加“EntityType”作为 PartitionKey,将“PK”添加为 SortKey。这样我就可以以一种高性能的方式查询我的所有实体。
关于amazon-web-services - DynamoDB 单表设计 : How to get all entities of a type,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64952127/
我是一名优秀的程序员,十分优秀!