对私人默认区域的查询结果有任何限制Cloudkit?我不知道为什么,我只接受前100条记录与下面的查询:私有区域的CKQuery只返回来自CloudKit的前100条CKRecords
let p = NSPredicate(format: "(type == 'entered') AND (timestamp >= %@) AND (timestamp <= %@)", from, to)
let q = CKQuery(recordType: self.beaconRecordType, predicate: p)
q.sortDescriptors = [NSSortDescriptor(key: "timestamp", ascending: true)]
self.privateDatabase?.performQuery(q, inZoneWithID: nil, completionHandler: { results, error in
//count = 100
println(results.count)
}
好。正如Edwin在答案中提到的,解决方案是使用CKQueryOperation获取数据的初始块,然后使用completionBlock中的“游标”来触发另一个操作。这里有一个例子:
UPDATE
func fetchBeacons(from:NSDate, to:NSDate) {
let p = NSPredicate(value: true)
let q = CKQuery(recordType: self.beaconRecordType, predicate: p)
let queryOperation = CKQueryOperation(query: q)
queryOperation.recordFetchedBlock = fetchedARecord
queryOperation.queryCompletionBlock = { [weak self] (cursor : CKQueryCursor!, error : NSError!) in
if cursor != nil {
println("there is more data to fetch")
let newOperation = CKQueryOperation(cursor: cursor)
newOperation.recordFetchedBlock = self!.fetchedARecord
newOperation.queryCompletionBlock = queryOperation.queryCompletionBlock
self!.privateDatabase?.addOperation(newOperation)
}
}
privateDatabase?.addOperation(queryOperation)
}
var i = 0
func fetchedARecord (record: CKRecord!) {
println("\(NSDate().timeIntervalSinceReferenceDate*1000) \(++i)")
}
确定。我找到了这个。 http://stackoverflow.com/a/27135836/893771。尽管如此,一段代码仍会有所帮助。 – CppChase
[This answer](http://stackoverflow.com/a/27728609/1966109)对一个类似的问题也展示了如何保持对'queryOperation'的强引用,以防止你的抓取在不完整时结束。 –
此解决方案将导致操作只运行3次!,请改用此代码:http://stackoverflow.com/a/31664231/530884 – Shaybc