是否可以使用Swift在一个CKRecord
操作中保存多个CloudKit
个对象?我知道如何使用CKFetchRecordsOperation
甚至只是常规performQuery
之类的内容一次检索多条记录。我刚刚意识到我不确定在一次操作中保存多个新记录的方法。到目前为止我一直这样做的方式对我来说似乎效率低下。例如:
let recordsToSave:[CKRecord]!
for newRecord in recordsToSave {
if let database = self.publicDatabase {
database.saveRecord(newRecord, completionHandler: { (record:CKRecord?, error:NSError?) in
// Check if there was an error
if error != nil {
// There was an error, handle it properly.
}
else {
// There wasn't an error
if let savedRecord = record {
// Handle saved record accordingly.
}
}
})
}
虽然这确实很好用,但在我看来它似乎效率极低。我认为让一个特定的函数调用以保存整个CKRecords
数组会更有意义,而不是每次都要通过循环调用数据库。基本上这就是我希望我可以做的事情:
let recordsToSave:[CKRecord]!
if let database = self.publicDatabase {
// SOMETHING HERE LIKE database.saveRECORDS (plural) ????
database.saveRecords(recordsToSave, completionHandler: { (records:[CKRecord]?, error:NSError?) in
// Check if there was an error
if error != nil {
// There was an error, handle it properly.
}
else {
// There wasn't an error
if let savedRecords = records {
}
}
})
}
尽我所知,并根据我获得的信息。没有像database.saveRecords
(复数)这样的实际功能。除非我错过了什么?我认为它不是那么切割和干燥,命名是不同的,但我认为必须有类似的东西。
每次循环时都必须进行数据库调用,这似乎非常低效。
是否有人知道使用CKRecords
一次为多个CloudKit
执行保存的方法?任何帮助都将非常感激。提前谢谢!
答案 0 :(得分:10)
在循环中使用saveRecord
非常低效。实际上最好避免使用CKDatabase
上的所有便捷方法并使用适当的操作。
要添加/修改/删除一个或多个记录,请使用CKModifyRecordsOperation
。您可以通过单个操作添加/修改以及删除任意数量的记录。这比使用saveRecord
要高效得多。
我建议您浏览CloudKit Framework Reference以查看完整的可用操作列表。
答案 1 :(得分:0)
为了建立在 rmaddy 所说的基础上,这里有一个示例代码,如果您在“delete”参数中添加一个 CKRecords 数组(我在这里为 nil),它也适用于删除。这就是我的意思:
let db = CKContainer.default().publicCloudDatabase
let operation = CKModifyRecordsOperation.init(recordsToSave: recordsToSave, recordIDsToDelete: nil)
operation.modifyRecordsCompletionBlock = { _, _, error in
if let error = error{
print(error.localizedDescription)
let alert = UIAlertController(title: "Operation Failed", message: "There was a problem interacting with some records.", preferredStyle: .alert)
let ok = UIAlertAction(title: "Ok", style: .cancel, handler: nil)
alert.addAction(ok)
self.present(alert, animated: true, completion: nil)
}
}
db.add(operation)