В 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
}

Часто вам захочется создавать блоки обработчиков многократного использования при работе с курсорами, чтобы вы могли рекурсивно создавать операции запросов на основе курсора, если поступает более одного.

Другие вопросы по тегам