我尝试了很多不同的方法来获取记录并在stackoverflow上检查相同的问题但是不能提取超过100条记录。
之前,我使用CKQuery而不是CKQueryOperation来使用resultsLimit
参数。
这是我的代码:
func initData(){
// show activity indicator
self.activityIndicatorView.hidden = false
// hide connection error button
self.connectionErrorButton.hidden = true
let container = CKContainer.defaultContainer()
let publicDB = container.publicCloudDatabase
let predicate = NSPredicate(value: true)
let sort = NSSortDescriptor(key: "id", ascending: true)
var newInfo = Array<CKRecord>()
let query = CKQuery(recordType: "info", predicate: predicate)
query.sortDescriptors = [sort]
let queryOperation = CKQueryOperation(query: query)
queryOperation.queuePriority = .VeryHigh
queryOperation.resultsLimit = 150;
// Fetch the pokemons for the record
func fetched(record: CKRecord!) {
newInfo.append(record)
}
queryOperation.recordFetchedBlock = fetched
queryOperation.queryCompletionBlock = { [unowned self] (cursor, error) in
if (error != nil) {
dispatch_async(dispatch_get_main_queue()) {
self.connectionErrorButton.hidden = false
self.activityIndicatorView.hidden = true
return
}
} else {
dispatch_async(dispatch_get_main_queue()) {
self.infos.removeAll()
self.infos = newInfo
self.tableView.reloadData()
self.activityIndicatorView.hidden = true
return
}
}
}
publicDB.addOperation(queryOperation)
}
答案 0 :(得分:2)
在iOS 9.3及更低版本中,您需要使用CKQueryCursor
执行多次抓取操作,并跟踪抓取中的位置。那就是在完成块中传回的光标对象,你可以用它创建另一个操作,它会在你离开的地方拾取它,如下所示:
queryOperation.queryCompletionBlock = { (cursor, error) in
if let cursor = cursor {
let cursorOperation = CKQueryOperation(cursor: cursor)
cursorOperation.queryCompletionBlock = //Handle it again
}
//Do stuff
}
通常,您在使用游标时希望创建可重用的处理程序块,以便在多个游标到达时可以递归地创建基于游标的查询操作。