我有一个RecordType Account
和另一个Friends
。
对于Account
我在创建每条记录时设置RecordID
,我有一列Name
。
对于朋友,我有两列,Me
和MyFriend
。 MyFriend
是包含帐户RecordID
的参考。
如何检索作为朋友的帐户名称?
我需要查询Friends以获取Me
为RecordID
的所有记录,然后我需要使用这些记录的引用来从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)`
答案 0 :(得分:5)
如果MyFriend是CKReference,那么你不应该将它转换为字符串而是转发给CKReference,然后将其转换为recordID.recordName。所以代码看起来像这样:
var myFriend = friend.objectForKey("MyFriend") as CKReference
var key = myFriend.recordID.recordName