Rob van den Berg
Rob van den Berg

Reputation: 820

How to query CloudKit for recordID IN [CKRecordID]

My predicate wants to exclude some records that are already downloaded and available in a [CKRecordID]. Now I can query 1 CKRecordID[0], but not the [CKRecordID] array. How can I query the array?

let excludeIDs: [CKRecordID]

This works:

let pred1 = NSPredicate(format: "NOT(recordID = %@)", excludeIDs[0])

But this doesn't:

let pred1 = NSPredicate(format: "NOT(recordID IN %@)", excludeIDs)

ERROR: loadImageCompareRecordIDsAndEndDateThatHaveNotEnded Error: Invalid predicate: Invalid predicate: Array members must conform to CKRecordValue: ( "", "", "", "", "" ) (CKRecordID)

The other general parts of the code:

    let sort = NSSortDescriptor(key: "creationDate", ascending: false)
    let query = CKQuery(recordType: MyRecordTypes.ImageCompare, predicate: pred1)
    query.sortDescriptors = [sort]
    let operation = CKQueryOperation(query: query)
    operation.desiredKeys = ["endDate"]
    operation.resultsLimit = 50

Upvotes: 9

Views: 2175

Answers (2)

Dave Thompson
Dave Thompson

Reputation: 75

To be explicit (because it took me hours to get this right)...

let refs = excludeIDs.map { CKRecord.Reference(recordID: $0.recordID, action: .none) }
let pred1 = NSPredicate(format: "NOT(recordID IN %@)", refs)

Upvotes: 1

Rob van den Berg
Rob van den Berg

Reputation: 820

Using [CKReference] and not [CKRecordID] solved it.

Upvotes: 8

Related Questions