ios - 将新对象添加到具有一对多关系的 CoreData

标签 ios swift core-data nsnotificationcenter

我有这样的 CoreData 模型:

enter image description here

包裹只能有一个公司,但公司可以有多个包裹派送。

我在数据库中预加载了三个公司。我创建了带有部分的 TableView 并通过 NSFetchedResultsController 加载数据。 我正在这样配置它:

let fetchRequest = NSFetchRequest(entityName: EnityNames.PackageInfoEnityName)

        // Add Sort Descriptors
        let sortDescriptor = NSSortDescriptor(key: PackageInfoKeyPaths.Company, ascending: true)
        fetchRequest.sortDescriptors = [sortDescriptor]

        // Initialize Fetched Results Controller
        let fetchedResultsController = NSFetchedResultsController(fetchRequest: fetchRequest, managedObjectContext: self.managedObjectContext, sectionNameKeyPath: PackageInfoKeyPaths.Company, cacheName: nil)

        // Configure Fetched Results Controller
        fetchedResultsController.delegate = self

        return fetchedResultsController

当我在模拟器上启动应用程序时,我有三个部分(正如预期的那样),我希望显示公司部分,所以我使用关系作为部分名称关键路径:

number of sections 3
FedEx
UPS
DHL

我创建了弹出窗口,我可以在其中向数据库添加新条目以使用其他数据填充列表。这是我用来创建和保存新数据的代码:

let appDelegate = UIApplication.sharedApplication().delegate as! AppDelegate
        let package = 

    NSEntityDescription.insertNewObjectForEntityForName(EnityNames.PackageInfoEnityName, inManagedObjectContext: managedObjectContext) as! PackageInfo
            let formatter = NSNumberFormatter()
            formatter.numberStyle = .DecimalStyle
            package.parcelNumber = formatter.numberFromString(parcelNumberTextField.text!) ?? 0;
            package.createdAt = NSDate()
            let company = avaialbleCompanies![companyPickerView.selectedRowInComponent(0)]
            package.company_relation = company
            company.addPackageToCompany(package)    


            appDelegate.saveContext()

companies 数组被传递到 prepare for segue 到我的小弹出窗口,让用户只选择数据库内的公司。在此之后我得到了一些奇怪的东西:

number of sections 4
FedEx
UPS
UPS

为什么要添加新的部分?它应该只是将新项目添加到现有部分!

和可怕的错误:

PackageChecker[5336:281349] CoreData:错误:严重的应用程序错误。在调用 -controllerDidChangeContent: 期间从 NSFetchedResultsController 的委托(delegate)捕获了一个异常。无效更新:无效的节数。更新后 TableView 中包含的节数(4)必须等于更新前 TableView 中包含的节数(3),加上或减去插入或删除的节数(0插入,0删除)。与用户信息(空)

重要的部分可能是我得到了这个:

updated index path 1x0

我正在使用 fetchedResultsController.sections?.count 来获取部分的数量。 如果我在 sim 上重新启动应用程序,我新添加的记录会出现在列表中的适当部分。为什么它在运行时没有正确更新?

附言我有:

func controllerWillChangeContent(controller: NSFetchedResultsController) {
        self.tableView.beginUpdates()
    }

    func controllerDidChangeContent(controller: NSFetchedResultsController) {
        self.tableView.endUpdates()
    }

编辑:

如果我删除 sectionNameKeyPath: PackageInfoKeyPaths.Company - 添加效果很好。你能帮我处理这部分吗?也许我配置不当。

最佳答案

发生崩溃是因为 FRC 正在创建一个新部分,但您的代码当前没有创建相应的 tableView 部分。如果您实现 NSFetchedResultsControllerDelegate 方法:

controller:didChangeSection:atIndex:forChangeType:

这应该可以解决崩溃问题。

但恐怕我不明白 FRC 为什么要创建一个新部分。

关于ios - 将新对象添加到具有一对多关系的 CoreData,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34779211/

相关文章:

iOS SQLite 数据存储 - 更新 VS。重新创造

ios - UIAlertView破坏AVPlayer的音频进程

Swift Firebase 在整个应用程序中重用一个函数

ios - 错误: Could not find overload for 'title' that accepts the supplied arguments

swift - 无法将 Int 类型的值转换为预期的参数类型 IndexPath(核心数据)?

iphone - NSArray 中的 SQL Sum 和 If/Case 语句

ios - FMDatabaseQueue 如何返回一个值

使用 switch、case 和 fallthrough 的 Swift 示例代码

ios - 如何为 NSURLRequest 设置 x-access-token?

ios - 向 CoreData 实体添加方法和属性的正确方法是什么?对它们进行子类化?