我知道整个设计应该基于自然聚合(文档),但是我正在考虑为本地化(语言、键、文本)实现一个单独的表,然后在其他表中使用键。但是,我找不到任何关于这样做的例子。
任何指针可能会有所帮助!
最佳答案
你是对的,DynamoDB 不是作为关系数据库设计的,不支持连接操作。您可以将 DynamoDB 视为一组键值对。
您可以在多个表中使用相同的键(例如 document_ID),但 DynamoDB 不会自动同步它们或具有任何外键功能。一个表中的 document_ID 虽然名称相同,但在技术上与不同表中的文档 ID 是不同的集合。由您的应用程序软件来确保这些 key 是同步的。
DynamoDB 是一种不同的数据库思考方式,您可能需要考虑使用托管关系数据库,例如 Amazon Aurora:https://aws.amazon.com/rds/aurora/
需要注意的一件事是,Amazon EMR 确实允许联接 DynamoDB 表,但我不确定这是否是您要查找的内容:http://docs.aws.amazon.com/ElasticMapReduce/latest/DeveloperGuide/EMRforDynamoDB.html
关于amazon-web-services - 如何加入 AWS DynamoDB 中的表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36753861/