假设您有部门和员工,每个部门都有几名员工,但每个员工也可以成为多个部门的一部分。

因此,员工与部门之间存在多对多的关系。删除部门时,我想删除仅属于该部门的所有员工,并取消与该部门的关系,以便同时也是其他部门成员的所有员工。

两个方向的级联规则是否会这样做?或者级联规则是否会自动删除某个部门的所有员工,而不考虑其他所属部门?

有帮助吗?

解决方案

级联规则将自动删除目标处的对象。因此,如果删除某个部门,员工将被删除,无论他们所在的部门数量是多少。

听起来你想要的行为有点细微之处,只删除“孤儿”行为。员工 - 即没有部门的员工。删除部门时,找到这些部门的好方法就是做这样的事情:

NSManagedObject *doomedDepartment = // get the department to be deleted

NSSet *employees = [doomedDepartment valueForKey:@"employees"];
NSSet *orphanedEmployees = [employees filteredSetUsingPredicate:[NSPredicate predicateWithFormat:@"departments.@count == 1"]];
for (NSManagedObject *orphanedEmployee in orphanedEmployees) {
    [managedObjectContext deleteObject:orphanedEmployee];
}    

[managedObjectContext deleteObject:doomedDepartment];

其他提示

谢谢,亚历克斯。我可能会这样做。 与此同时,我找到了另一种方法:

1。)注册变更通知:

    [[NSNotificationCenter defaultCenter] addObserver:self 
            selector:@selector(managedObjectContextDidChange:) 
            name:NSManagedObjectContextObjectsDidChangeNotification 
            object:managedObjectContext];

2。)当发生变化并且员工得到更新时。我检查该对象是否与部门有0关系并删除它:

- (void)managedObjectContextDidChange:(NSNotification *)notification {
    NSSet *updatedObjects = [[notification userInfo] objectForKey:NSUpdatedObjectsKey];

for(NSManagedObject *obj in updatedObjects){        
    // walk through updated objects -> check for employees
    // check if they still contain departments and if not delete them
    if([obj.entity.name isEqualToString:@"Employee"]){
        NSLog(@"Employee changed!");
        if([[(Employee*)obj Departments] count]==0){
            NSLog(@"No more relations -> Delete Employee");
            [managedObjectContext deleteObject:obj];
        }
    }
}}

这也很有效,但是如果你有几个不同的实体来观察这种行为,可能会变得更复杂。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top