AWS DynamoDB Scan filterExpression - 简单数字比较

时间:2015-03-04 15:04:15

标签: amazon-web-services expression amazon-dynamodb

我正在尝试使用过滤器表达式(documentation here

进行简单的dynamoDB扫描

这是我的表达式字符串:

"attribute_exists("my_db_key") AND ("my_db_key" = 1)"

这简单地说明:

"如果my_db_key的值存在且my_db_key EQUALS 1,请在结果中返回"

然而它不起作用我收到了这个错误:

Invalid FilterExpression: Syntax error; token: "1", near: "= 1)

我知道我可以为值使用属性值占位符,然后在表达式中使用它,但我不想这样做。根据亚马逊的文档,这不是必需的。

那我该怎么做这个简单的表达呢?有没有人有文档的示例或链接?遗憾的是,亚马逊的文档没有任何帮助。

注意:我在iOS上使用AWSDynamoDBScanInput实现此功能,但我的问题是与全局表达式语法有关,因此无关紧要。

2 个答案:

答案 0 :(得分:4)

你的params需要看起来像这样(对于Node AWS库):

params = {
  "FilterExpression": 'attribute_exists("my_db_key") AND ("my_db_key" = :value)',
  "ExpressionAttributeValues": {
    ":value": 1
  },
  // ...
};

docClient.scan(params, function(err, data){
  // Handle err or process data
})

对于某些语言,参数看起来应该更像这样:

{
  "FilterExpression": 'attribute_exists("my_db_key") AND ("my_db_key" = :value)',
  "ExpressionAttributeValues": {
    ":value": {"N":1}
  },
  // ...
};

答案 1 :(得分:1)

您必须使用占位符并单独传递值。这里有一些documentation和一个Post from AWS forums