如何仅使用分区键从 aws Dynamodb 获取数据?
How to get data from aws Dynamodb with using partition key only?
我在 Golang 中使用 aws-sdk-go 库进行 DynamoDb 连接。
我的 DynamoDb table 有一个分区键 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)
您必须使用 Query 或 Scan 操作,这是一个简单的示例,但您可以在 Amazon 文档上阅读更多内容 here
特别是查询操作
A Query operation finds items in a table or a secondary index using only primary key attribute values
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
}
此时可以使用查询操作
以下是相同的一个通用示例
compositeKey := entity.GetPrimaryKey(inputVar)
expressionAttributeValues := map[string]*dynamodb.AttributeValue{
":v1": {
S: aws.String(compositeKey.PartitionKey.Data.(string)),
},
}
queryInput := dynamodb.QueryInput{
TableName: &d.TableName,
KeyConditionExpression: aws.String("id = :v1"),
ExpressionAttributeValues: expressionAttributeValues,
}
queryOutput, err := d.DdbSession.Query(&queryInput)
if err != nil {
log.Error("error in fetching records ", err)
return nil, err
}
// unmarshal the query output - items to interface
err = dynamodbattribute.UnmarshalListOfMaps(queryOutput.Items, &yourInterface)
您可以像这样在 JavaScript SDK v2 中使用 getItem
const params = {
TableName: 'tableName',
Key: {
id: { S: id },
},
};
const result = await dynamoDb.getItem(params).promise();
if (result.Item === undefined) {
throw new Error('not found');
}
const item = AWS.DynamoDB.Converter.unmarshall(result.Item)
如果JavaScriptSDK可以做到这一点,我想golang SDK也可以。如果不是,那意味着 AWS 不会平等对待所有语言?
我在 Golang 中使用 aws-sdk-go 库进行 DynamoDb 连接。
我的 DynamoDb table 有一个分区键 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)
您必须使用 Query 或 Scan 操作,这是一个简单的示例,但您可以在 Amazon 文档上阅读更多内容 here
特别是查询操作
A Query operation finds items in a table or a secondary index using only primary key attribute values
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
}
此时可以使用查询操作
以下是相同的一个通用示例
compositeKey := entity.GetPrimaryKey(inputVar)
expressionAttributeValues := map[string]*dynamodb.AttributeValue{
":v1": {
S: aws.String(compositeKey.PartitionKey.Data.(string)),
},
}
queryInput := dynamodb.QueryInput{
TableName: &d.TableName,
KeyConditionExpression: aws.String("id = :v1"),
ExpressionAttributeValues: expressionAttributeValues,
}
queryOutput, err := d.DdbSession.Query(&queryInput)
if err != nil {
log.Error("error in fetching records ", err)
return nil, err
}
// unmarshal the query output - items to interface
err = dynamodbattribute.UnmarshalListOfMaps(queryOutput.Items, &yourInterface)
您可以像这样在 JavaScript SDK v2 中使用 getItem
const params = {
TableName: 'tableName',
Key: {
id: { S: id },
},
};
const result = await dynamoDb.getItem(params).promise();
if (result.Item === undefined) {
throw new Error('not found');
}
const item = AWS.DynamoDB.Converter.unmarshall(result.Item)
如果JavaScriptSDK可以做到这一点,我想golang SDK也可以。如果不是,那意味着 AWS 不会平等对待所有语言?