3

我的 CoreData 模型有两个子实体“CarA”和“CarB”,它们具有相同的抽象父实体“Car”。

我正在尝试使用删除所有 CarA 对象

    func deleteObjects(entityName: String) {
        let fetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: entityName)
        let deleteRequest = NSBatchDeleteRequest(fetchRequest: fetchRequest)
        do {
            try context.execute(deleteRequest)
        } catch let error as NSError {
            print(error)
        }
    }

执行deleteObjects("CarA")导致不仅删除所有 CarA 对象,还删除所有 CarB 对象。

4

1 回答 1

3

这在我看来就像一个错误。如果启用 SQLDebug,您可以从控制台输出中看到整个父实体已被删除:

CoreData: sql: BEGIN EXCLUSIVE
CoreData: sql: DELETE FROM ZABSTRACT
CoreData: sql: COMMIT

(我的父实体名为“Abstract”)。但我注意到,如果您添加谓词,CoreData 会记住限定底层提取以将其限制为正确的子实体。因此,一种解决方法是添加一个始终为真的谓词:

fetchRequest.predicate = NSPredicate(value:true)

结果控制台输出为:

CoreData: sql: BEGIN EXCLUSIVE
CoreData: sql: DELETE FROM ZABSTRACT WHERE Z_PK IN (SELECT t0.Z_PK FROM ZABSTRACT t0 WHERE  t0.Z_ENT = ? )
CoreData: sql: COMMIT

似乎 CoreData 甚至优化了真正的谓词,只留下 WHERE 子句来限制删除到正确的实体。

于 2017-12-11T23:15:40.763 回答