CloudKit ___recordID 未标记为可查询

CloudKit ___recordID is not marked queryable

我尝试以编程方式成功地将数据保存到 CloudKit,但是当我从 CloudKit

获取数据时出现错误

我收到一个错误

> <CKError 0x608000052060: "Invalid Arguments" (12/2015); server message
> = "Field '___recordID' is not marked queryable"; uuid = 19F1E556-5384-42FD-8F65-9FD8A9C9523D; container ID =
> "iCloud.com.mywebsite.CloudDemo">

这是我的代码。

func saveNewRecordTypeToCloud()  {
        // Prepare the record to save
        var record = CKRecord(recordType: "Members")
        record.setValue("test", forKey: "name")
        record.setValue("test", forKey: "surname")

        // Get iCloud Database
        let cloudContainer = CKContainer.defaultContainer()
        let database = CKContainer.defaultContainer().privateCloudDatabase

        // Save the record to iCloud
        database.saveRecord(record, completionHandler: { (record:CKRecord!, error:NSError! ) in
            if error != nil {
                NSLog(error.localizedDescription)
            } else {
                dispatch_async(dispatch_get_main_queue()) {
                    println("finished")
                }
            }
        })



    }



 func getRecordsFromCloud() {
        // Fetch data using Convenience API
        let cloudContainer = CKContainer.defaultContainer()
        let publicDatabase = CKContainer.defaultContainer().privateCloudDatabase
        let predicate = NSPredicate(value: true)
        let sort = NSSortDescriptor(key: "creationDate", ascending: false)
        let query = CKQuery(recordType: "Members", predicate: predicate)
        query.sortDescriptors = [sort]
        publicDatabase.performQuery(query, inZoneWithID: nil, completionHandler: {
            results, error in
            if error == nil {


                self.members = results as! [CKRecord]

                println(self.members)



            } else {
                println(error)
            }
        }) }

为了解决这个问题,我不得不通过 Web DashBoard 设置元数据索引,但我想知道我是否可以通过代码设置元数据索引?

如果是这样,请给我一些代码示例。

谢谢大家的回答。

抱歉,无法通过代码设置索引。您必须在 CloudKit 仪表板中执行此操作。