我有下面的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控制台执行相同的扫描时得到相同的结果:
ios - 使用排序键作为filterExpression时,为什么AWSDynamoDBScanExpression返回空?-LMLPHP
我使用AWSDynamoDBScanExpression有什么问题?
我尝试使用其他扫描配置:
不设置filterExpression=>OK,最多返回10个项目
#id = :id=>好,返回最多10个BoardId=1的项目
contains(#dt, :dt)=>没有错误,但也返回空结果
scanExpression.indexName设置为某些索引,其中“DateTime”不是排序键(例如,“BoardId”是分区键,“Type”是排序键)=>确定,返回与web控制台相同的正确项
不允许将排序键用作筛选表达式吗?
AWS SDK for iOS docsAWS Working with Scan docs中没有提到这一点(这里甚至声明“使用Scan,您可以在过滤器表达式中指定任何属性,包括分区键和排序键属性”)

最佳答案

我会尝试从扫描参数中删除scanExpression.limit = 10
https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Scan.html#DDB-Scan-request-Limit:“要评估的项目的最大数量(不一定是匹配项目的数量)”。
所以可能发生的情况是扫描查看了10个项目,然后应用过滤器,过滤器没有匹配其中任何一个,而您没有得到任何结果

10-07 21:57