我在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文档中进行查找,但找不到任何内容。任何帮助,将不胜感激。
谢谢
您的错误在于如何格式化查询表达式中的哈希键值。适用于Ruby的v2 AWS开发工具包(aws-sdk
gem)接受所有属性值作为原始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时,以下博客系列可能会有所帮助:
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句