我正在尝试使用过滤器表达式(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实现此功能,但我的问题是与全局表达式语法有关,因此无关紧要。
答案 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