如何解决DateTime在DynamoDB中为String,如何将DateTime属性保持为范围键?
我是DynamoDB的新手,在我们的应用程序中,访问模式将类似于,显示所有最近创建的订单。因此,我决定在DynamoDB中进行数据建模时,将createdDateTime属性保留为范围键。我也看到很多帖子建议将dateTime保存为ISO_8601格式的String。 DynamoDB中的排序将如何发生。在获取订单列表时,我想先获取最新信息。
解决方法
由于许多不同的业务原因,想要显示最近创建的任何内容是相对常见的要求。
大多数情况下,有两件事是正确的:
- “最近创建的”列表通常是固定大小的有序列表
- 这是一个时间点快照,并且取决于创建内容的速度,即使返回列表,列表也可能不准确
这样,您可以考虑使用一个辅助系统来存储最近创建的项目,该系统不一定与您自己存储项目的位置相同。
该方法很大程度上取决于创建新项目的速度。例如,在每秒创建许多新订单的系统中,可以使用缓存或某些流处理器来获取N个最近创建的订单。
但是,如果速度接近每小时订单,则可以通过Dynamo中的单个记录来更好地实现最新的N个订单,在Dynamo中,您可以在创建每个新订单时使列表保持更新。
后一种方法可以达到约300个订单/秒的程度。除此之外,您还需要其他一些东西。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。