使用Swift对CloudKit进行CKReference

时间:2015-04-16 07:11:15

标签: ios swift cloudkit ckrecord ckreference

我有一个RecordType Account和另一个Friends。 对于Account我在创建每条记录时设置RecordID,我有一列Name

对于朋友,我有两列,MeMyFriendMyFriend是包含帐户RecordID的参考。

如何检索作为朋友的帐户名称? 我需要查询Friends以获取MeRecordID的所有记录,然后我需要使用这些记录的引用来从Account表中获取名称。

我尝试了以下但是没有结果:

let predicate = NSPredicate(format: "Me = %@", recordID)
let query = CKQuery(recordType: "Friends", predicate: predicate)
publicDB.performQuery(query, inZoneWithID: nil) { (results, error) -> Void in
    if error != nil {
        println("Error fetching from Friends table: \(error.description)")
    } else {
        for friend in results {
            var key = friend.objectForKey("MyFriend") as String
            self.publicDB.fetchRecordWithID(CKRecordID(recordName: key), completionHandler: { (record, error) -> Void in
                if error != nil {
                    println(error.description)
                } else {
                    self.friends.append(record.objectForKey("Name") as String)
                }
            })
        }
        dispatch_semaphore_signal(self.semaphore)
    }
 }
 dispatch_semaphore_wait(self.semaphore, DISPATCH_TIME_FOREVER)`

1 个答案:

答案 0 :(得分:5)

如果MyFriend是CKReference,那么你不应该将它转换为字符串而是转发给CKReference,然后将其转换为recordID.recordName。所以代码看起来像这样:

var myFriend = friend.objectForKey("MyFriend") as CKReference
var key = myFriend.recordID.recordName