В CloudKit не может быть более 100 записей
Я перепробовал много разных способов извлечения записей и проверил те же проблемы на стеке, но не смог получить более 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)
}
1 ответ
На 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
}
Часто вам захочется создавать блоки обработчиков многократного использования при работе с курсорами, чтобы вы могли рекурсивно создавать операции запросов на основе курсора, если поступает более одного.