可以使用DynamoDB的两个特性来解决这个问题:列表和映射。在此示例中,我们将使用映射来在DynamoDB表中存储一个对象数组。
首先,创建一个名为"table_name"的DynamoDB表,其中包含一个名为"primary_key"的主键和一个名为"my_map"的映射。在"my_map"中,我们将创建一个名为"item_id"的属性来存储数组中的每个对象唯一ID。
接下来,我们可以创建一个名为"gsi_name"的GSI,并将其分区键设置为"item_id"属性。当查询这个GSI时,它将返回完整的数组对象。
以下是用JavaScript SDK创建上述DynamoDB表和GSI的代码示例:
const AWS = require('aws-sdk');
AWS.config.update({ region: 'us-east-1' });
const dynamodb = new AWS.DynamoDB();
const params = {
TableName: 'table_name',
KeySchema: [
{ AttributeName: 'primary_key', KeyType: 'HASH' }
],
AttributeDefinitions: [
{ AttributeName: 'primary_key', AttributeType: 'S' },
{ AttributeName: 'my_map', AttributeType: 'M' }
],
ProvisionedThroughput: {
ReadCapacityUnits: 5,
WriteCapacityUnits: 5
},
GlobalSecondaryIndexes: [
{
IndexName: 'gsi_name',
KeySchema: [
{ AttributeName: 'my_map.item_id', KeyType: 'HASH' }
],
Projection: {
ProjectionType: 'ALL'
},
ProvisionedThroughput: {
ReadCapacityUnits: 5,
WriteCapacityUnits: 5
}
}
]
};
dynamodb.createTable(params, (err, data) => {
if (err) console.log(err);
else console.log(data);
});
注意,创建映射结构时,属性的路径应该以映射的属性名为前缀,例如"my_map.item_id"这样的格式。
使用此设置后,可以使用query或scan操作查询GSI并获得包含列表对象的完整结果。