首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用cloudkit ckqueryoperation进行批取

使用cloudkit ckqueryoperation进行批取
EN

Stack Overflow用户
提问于 2018-02-24 17:33:30
回答 2查看 476关注 0票数 1

是否可以在cloudkit中实现“批取”,以便调用一个方法来提取下一个X记录?目前,根据CloudKit批量Fetches? cloudkit的说法,它是隐式处理的,但我想以某种方式创建一个方法,允许我每次提取指定数量的查询。以下是我到目前为止所使用的方法:(其中continuePullPosts与我发布的方法类似)

代码语言:javascript
复制
queryOP.recordFetchedBlock = { record in
        //do stuff here
        annotations.append(postToAdd)
    }

    queryOP.queryCompletionBlock = { [unowned self] (cursor, error) in
        DispatchQueue.main.async {
            if error == nil {
                if completionHandler(annotations) {
                    if cursor != nil {
                        let newQueryOP = CKQueryOperation(cursor: cursor!)
                        self.continuePullPosts(curLocation: curLocation, queryOP: newQueryOP,
                                               annotations: annotations, completionHandler: completionHandler)
                    }
                }
            } else {
                print(error)
                print("could not pull posts")
            }
        }
    }

    queryOP.resultsLimit = CKQueryOperationMaximumResults
    CKContainer.default().publicCloudDatabase.add(queryOP)
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-02-27 09:43:09

您应该用所需的值来设置结果极限,而不是CKQueryOperationMaximumResults常量值。

我的建议是定义一个包含CKRecord结果和CKQueryCursor参数的完成处理程序。必须在queryCompletionBlock的CKQueryOperation处理程序中调用此完成处理程序。

一旦调用了处理程序,您就可以处理结果,如果游标不是null,则意味着需要获取更多的结果。

可能是这样的

代码语言:javascript
复制
// Completion Handler (closure) definition
public typealias YourFetchCompletionHandler = (_ records: [CKRecords]?, cursor: CKQueryCursor?) -> (Void)

在这里,您获取记录的函数

代码语言:javascript
复制
public func fetchYourRecords(_ cursor: CKQueryCursor? = nil, completionHandler handler: @escaping YourFetchCompletionHandler) -> Void
{
    var result: [CKRecord] = [CKRecord]()

    let queryOP: CKQueryOperation

    if let cursor = cursor
    {
        // Operation to fetch another 10 records.
        queryOP = CKQueryOperation(cursor: cursor)
    }
    else
    {
        // Create the operation for the first time
        queryOP = CKQueryCursor(query:...)
    }

    queryOp.recordFetchedBlock = { (record: CKRecord) -> Void in
        result.append(record)
    }

    queryOP.queryCompletionBlock = { [unowned self] (cursor, error) in
        handler(result, cursor)    
    }

    // Fetch only 10 records
    queryOP.resultsLimit = 10
    CKContainer.default().publicCloudDatabase.add(queryOP)
}

一旦调用这个函数,就可以将在闭包中返回的游标保存在一个变量中(如果不是0),再次调用该函数来恢复接下来的10条记录。

票数 3
EN

Stack Overflow用户

发布于 2020-11-21 21:54:43

所以@Adolfo的回答让我得到了95%的答案,但我有一个问题:

每次到达最后一页(或批处理)或数据时,它都会从数据集的开始向我发送数据。

这是一个问题,因为在我用完数据后,我希望停止加载。

为了解决这个问题,我添加了一个参数来指定它是否是第一个fetch。这只允许我在第一个fetch时创建一个新查询。如果不是第一个fetch,就不会进行新的查询,也不会返回一个空数组。

代码语言:javascript
复制
public func fetchYourRecords(isFirstFetch: Bool, _ cursor: CKQueryCursor? = nil, completionHandler handler: @escaping YourFetchCompletionHandler) -> Void {
    var result: [CKRecord] = [CKRecord]()
    let queryOP: CKQueryOperation
    
    if isFirstFetch {
        // Create the operation for the first time

        queryOP = CKQueryCursor(query:...)
    } else if let cursor = cursor {
        // Operation to fetch another 10 records.

        queryOP = CKQueryOperation(cursor: cursor)
    } else {
        // If not first time and if cursor is nil (which means
        // there is no more data) then return empty array
        // or whatever you want

        handler([], nil)
        return
    }

    queryOp.recordFetchedBlock = { (record: CKRecord) -> Void in
        result.append(record)
    }

    queryOP.queryCompletionBlock = { [unowned self] (cursor, error) in
        handler(result, cursor)    
    }

    // Fetch only 10 records
    queryOP.resultsLimit = 10
    CKContainer.default().publicCloudDatabase.add(queryOP)
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48965667

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档