17

我有一个可能有很多记录的“表”,在添加新记录时,我需要知道当前表中已经有多少记录,因为我在计算某些值时使用它。我能找到的最接近的事情是请求所有这样的条目:

var query : CKQuery = CKQuery(recordType: "Stars", predicate: NSPredicate(format: "mass > 0"))
    var request : CKQueryOperation = CKQueryOperation(query: query)
    var starCount = 0

    request.queryCompletionBlock = {
        (cursor:CKQueryCursor!, error:NSError!) in
        if error {
            completionHandler(ECOResponse.error(error.description), starCount)
        } else {
            completionHandler(ECOResponse.ok(), starCount)
        }
    }

    request.recordFetchedBlock = {
        (record:CKRecord!) in
        starCount += 1
    }

我希望 queryCompletionBlock 与 CKQueryCursor 一起提供计数或结果数组,但不幸的是它没有。

还有其他方法可以计算表中的行数吗?

4

2 回答 2

9

不,不可能获得符合您的查询的记录总数。同样通过枚举结果,答案可能是错误的。CloudKit 返回的记录数不固定。CloudKit 有一种机制来决定返回多少记录。可以在 CKQueryOperation 对象上将其设置为固定数字。默认值为:

operation.resultsLimit = CKQueryOperationMaximumResults;

该属性的文档说:

使用该值时,服务器会选择一个限制,旨在提供最佳数量的结果,返回尽可能多的记录,同时最大限度地减少接收这些记录的延迟。但是,如果您知道要处理固定数量的结果,请相应地更改此属性的值。

如果您的计数与此固定数字相同,则可能有比您返回的查询更多的记录。

于 2014-07-23T12:47:18.323 回答
4

以非迭代方式获取与查询匹配的记录总数是不可能的,但可以迭代地进行。

CKQueryOperation将允许您获取查询的所有可能结果,但是,可能只能通过多个后续操作:If the search yields many records, the operation object may deliver a portion of the total results to your blocks immediately, along with a cursor for obtaining the remaining records. 来源:CKQueryOperation您可以忽略CKRecord通过返回的所有实例CKQueryOperation recordFetchedBlock并简单地增加您自己的NSUInteger计数器。在我的测试中,recordFetchedBlock调用的总次数始终与预期的查询结果数相匹配。

此外,为了提高效率,您可以使用 in 的desiredKeys属性CKQueryOperationto limit the amount of data retrieved for each record during the search operationsource: desiredKeysCKQueryOperation.h源文件中的注释说明If set to an empty array, declares that no user fields should be downloaded.

我测试了上面的场景,CKQueryOperation成功计数了数百条记录,因此超过了默认的CKQueryOperationMaximumResults批处理限制 100。

于 2019-02-16T10:12:53.663 回答