【问题标题】:AWS ruby sdk v2 - dynamodb queryAWS ruby​​ sdk v2 - dynamodb 查询
【发布时间】:2015-05-18 22:13:23
【问题描述】:

我在 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 amazon-web-services amazon-dynamodb


【解决方案1】:

您的错误在于您如何格式化查询表达式中哈希键的值。 v2 AWS SDK for Ruby (aws-sdk gem) 接受所有属性值作为普通 Ruby 值。

可以是:

  • 字符串
  • 数字(整数、浮点数、BigDecimal 等)
  • 布尔值
  • IO(blob 类型)
  • 集合(数字/字符串)
  • 数组(
  • 哈希(字符串 =>

您不需要像 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 时会有所帮助:

【讨论】:

  • 使用上面的提示来查看我的查询工作,感到如释重负!这就像大海捞针……谢谢!
  • comparison_operattor [ 错字]
猜你喜欢
  • 1970-01-01
  • 2018-11-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多