GolangのDynamoDb接続にaws-sdk-goライブラリを使用しています。
私のDynamoDbテーブルには、パーティションキーDeviceId(文字列)とソートキー時間(数値)があります。 GetItemInputを記述して、特定のDeviceIdを持つすべてのデータを取得するにはどうすればよいですか?
params := &dynamodb.GetItemInput{
Key: map[string]*dynamodb.AttributeValue {
"DeviceId": {
S: aws.String("item_1"),
},
},
ExpressionAttributeNames: map[string]*string{
"DeviceId": "DeviceId",
},
TableName: aws.String("DbName"),
}
list, err := svc.GetItem(params)
クエリまたはスキャン操作を使用する必要があります。これは簡単な例ですが、Amazonのドキュメントで詳細を読むことができます ここ
特に、クエリ操作
クエリ操作は、主キー属性値のみを使用して、テーブルまたはセカンダリインデックス内のアイテムを検索します
var queryInput = &dynamodb.QueryInput{
TableName: aws.String(dynamoRestDataTableName),
KeyConditions: map[string]*dynamodb.Condition{
"DeviceId": {
ComparisonOperator: aws.String("EQ"),
AttributeValueList: []*dynamodb.AttributeValue{
{
S: aws.String("aDeviceId"),
},
},
},
},
}
var resp, err = dynamoSvc.Query(queryInput)
if err != nil {
return nil, err
}