我在DynamoDB中有一个哈希(字符串)和范围(数字)表。我尝试使用ruby SDK v2.0.30运行查询,但不断收到以下错误:
aws-sdk-core-2.0.30/lib/seahorse/client/plugins/raise_response_errors.rb:15:in `call': One or more parameter values were invalid: Condition parameter type does not match schema type (Aws::DynamoDB::Errors::ValidationException)
这是我的代码:
gem 'aws-sdk', '~> 2'
require 'aws-sdk'
dynamodb = Aws::DynamoDB::Client.new(region: 'eu-west-1', credentials: creds)
resp = dynamodb.query(
table_name: "TEST_TABLE",
key_conditions: {
'ID' => {
comparison_operator: 'EQ',
attribute_value_list: [{ 's' => 'test123' }]
}
})
我是ruby的新手并尝试在线查看AWS文档但却无法找到任何内容。任何帮助将不胜感激。
由于
答案 0 :(得分:9)
您的错误在于如何格式化查询表达式中哈希键的值。适用于Ruby的v2 AWS SDK(aws-sdk
gem)接受所有属性值作为vanilla Ruby值。
值 可以是:
您无需提供v1 AWS SDK for Ruby所需的类型提示。
ddb = Aws::DynamoDB::Client.new
ddb.query({
table_name: 'TEST_TABLE',
key_conditions: {
'ID' => {
comparison_operattor: 'EQ',
attribute_value_list: ['test-123']
}
}
})
此外,与您的问题没有直接关系,但在使用aws-sdk
gem中的DynamoDB时,您可能会发现以下博客系列有用: