我有下面的DynamoDB表:
BoardId | DateTime | Data | Type
-------------------------------------------------
1 | 20180424T123508Z | 68.1 | U
1 | 20181026T143233Z | 38.2 | T
1 | 20190108T120150Z | 38.1 | T
2 | 20180425T092311Z | 63.4 | U
“BoardId”是分区键,“DateTime”是排序键。
我想获取包含“2019”的“BoardId”=“1”和“DateTime”的条目。
我使用了AWSDynamoDBObjectMapper#scan来执行以下代码:
let dbObjMapper = AWSDynamoDBObjectMapper.default()
let scanExpression = AWSDynamoDBScanExpression()
scanExpression.limit = 10
scanExpression.filterExpression = "#id = :id AND contains(#dt, :dt)"
scanExpression.expressionAttributeNames = [
"#id" : "BoardId",
"#dt" : "DateTime"
]
scanExpression.expressionAttributeValues = [
":id" : "1",
":dt" : "2019"
]
dbObjMapper
.scan(Event.self, expression: scanExpression)
.continueWith(block: {
(task: AWSTask<AWSDynamoDBPaginatedOutput>!) -> Any? in
if let error = task.error as NSError? {
print("The request failed. Error: \(error)")
} else if let paginatedOutput = task.result {
print("The request was successful.")
print(paginatedOutput.items.count)
for event in paginatedOutput.items as! [Event] {
print(event)
}
}
return ()
})
但我得到的结果是空的。没有错误(“请求成功。”),但打印
paginatedOutput.items.count
为0我希望从DynamoDB web控制台执行相同的扫描时得到相同的结果:我使用
AWSDynamoDBScanExpression
有什么问题?我尝试使用其他扫描配置:
不设置
filterExpression
=>OK,最多返回10个项目#id = :id
=>好,返回最多10个BoardId=1的项目contains(#dt, :dt)
=>没有错误,但也返回空结果将
scanExpression.indexName
设置为某些索引,其中“DateTime”不是排序键(例如,“BoardId”是分区键,“Type”是排序键)=>确定,返回与web控制台相同的正确项不允许将排序键用作筛选表达式吗?
在AWS SDK for iOS docs或AWS Working with Scan docs中没有提到这一点(这里甚至声明“使用Scan,您可以在过滤器表达式中指定任何属性,包括分区键和排序键属性”)
最佳答案
我会尝试从扫描参数中删除scanExpression.limit = 10
。
从https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Scan.html#DDB-Scan-request-Limit:“要评估的项目的最大数量(不一定是匹配项目的数量)”。
所以可能发生的情况是扫描查看了10个项目,然后应用过滤器,过滤器没有匹配其中任何一个,而您没有得到任何结果