如何更新核心数据中的可转换属性

How to update transformable attribute in core data

我处于需要更新核心数据实体中的可转换属性的情况,直到现在我已经尝试了 google 和堆栈溢出的所有可能答案,但没有取得任何成果。

这是我在核心数据中保存对象的方法,我保存的对象是一个 NSMutablDictionary 类型的对象。

-(void)didSaveToCoreData :(NSMutableDictionary *)newDict
{

@try {
    AppDelegate *appDelegate  = [[UIApplication sharedApplication]delegate];

    NSManagedObjectContext *context = appDelegate.managedObjectContext ;

    DataModelSupport *entity = [NSEntityDescription insertNewObjectForEntityForName:@"CPIEntity" inManagedObjectContext:context];


    if (newDict != nil) {

        [entity.fixed_Model removeAllObjects];
        entity.fixed_Model = newDict;
    }

    NSError *error ;
    [context save:&error];
    if(error)
    {
        NSLog(@"Error in Saving Data");
    }
    else
    {
        [self didFetchFromCoreDataModel];
        NSLog(@"Successfully saved");
    }

}
@catch (NSException *exception) {
    [self spareMeFromTheCrash:exception];
}
@finally {

}

}

在这个方法中,我第一次保存了一个 19 key/value 的字典对象,并且我在 didFetchFromCoreDataModel 方法中正确地获取了它,但是当我刷新数据并获得 18 [=50] 的字典时=] 我使用相同的方法 didSaveToCoreData 将该字典保存在核心数据中,并以相同的方式从 didFetchFromCoreDataModel 中获取它,但它仍然显示 19 key/value

DataModelSupport 是 NSManagedObject 的子class。 在 DataModelSupport.h:

@property (nonatomic,weak) NSMutableDictionary *fixed_Model;

在DataModelSupport.m中:

@dynamic fixed_Model;

这是 DataModelSupport class。

现在在这个方法中,我从核心数据中获取相同的对象

-(void)didFetchFromCoreDataModel
{

@try {
    AppDelegate *appDelegate  = [[UIApplication sharedApplication]delegate];

    NSManagedObjectContext *context = appDelegate.managedObjectContext ;
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"CPIEntity" inManagedObjectContext:context];

    NSFetchRequest *request = [[NSFetchRequest alloc]init];
    [request setReturnsDistinctResults:YES];
    [request setReturnsObjectsAsFaults:NO];
    [request setResultType:NSDictionaryResultType];
    [request setEntity:entity];
    NSError *error ;

    NSArray *arr = [context executeFetchRequest:request error:&error];

    updatedfinalArr = [arr valueForKey:@"fixed_Model"];



    if(error)
    {
        NSLog(@"Error");
    }
    else
    {

    }

}
@catch (NSException *exception) {
    [self spareMeFromTheCrash:exception];
}
@finally {

}

}

这就是我的核心数据的样子:-

感谢任何帮助。

编辑

我现在在 didSaveToCoreData 方法中对我的代码进行了一些更改我正在使用这行代码按名称获取实体

NSEntityDescription *descriptor = [NSEntityDescription entityForName:@"CPIEntity" inManagedObjectContext:context];

这样我就不会在每次调用 didSaveToCoreData 方法时都创建新实体。

这就是我保存 NSMutlableDictionary 对象的方式

DataModelSupport *entity = [[DataModelSupport alloc]initWithEntity:descriptor insertIntoManagedObjectContext:context];
[entity.fixed_Model removeAllObjects]
entity.fixed_Model = newDict;

但我仍然没有得到正确的结果。 现在,当我使用编辑部分中解释的上述过程刷新数据并保存它并获取它时,我得到了更新的数据,但它增加了对象的数量,就像我第一次尝试获取数组中的 1 个对象时一样,并且在第二次尝试时,我得到了 2 个对象,它是这样的,所以当添加新数据时,它不会更新它,而是将它添加到实体的 fixed_Model 属性中并增加对象的数量。

最后,现在我正在使用这行代码在 didFetchFromCoreDataModel 方法中从数组中获取最后一个和更新对象

NSDictionary *ddd = [[arr valueForKey:@"fixed_Model"]lastObject];
updatedfinalArr = [NSMutableArray arrayWithObject:ddd];

你能缩小问题范围吗?

即。你能比较一下这两本词典吗..原始的有 19 个值,新的有 18 个值?

是否有特定的条目不是 'removed'?这可能指向 'delete'(或缺乏)的挑战。

或者,如果您完全替换内容,您在获取时会得到什么结果?

您的保存方法每次都会创建一个新的 CPIEntity 对象。因此,除非您删除代码中其他地方的旧对象,否则我怀疑您的 fetch 返回了几个对象,第一个对象的字典在 fixed_Model 属性中包含 19 个 key/value 对,而 second/subsequent 个对象包含 18 个 key/value 对。

保存时,应首先尝试获取现有对象,如果结果为零,则创建一个新对象。然后将 new/existing 对象的 fixed_Model 属性设置为您的新字典。

编辑

您仍然每次都插入一个新对象 (DataModelSupport *entity = [[DataModelSupport alloc]initWithEntity:descriptor insertIntoManagedObjectContext:context];)。请参阅下面的 "fetch or create" 示例:

AppDelegate *appDelegate  = [[UIApplication sharedApplication]delegate];
NSManagedObjectContext *context = appDelegate.managedObjectContext ;
NSEntityDescription *descriptor = [NSEntityDescription entityForName:@"CPIEntity" inManagedObjectContext:context];
NSFetchRequest *request = [[NSFetchRequest alloc]init];
request.entity = descriptor;
NSError *error;
NSArray *results = [context executeFetchRequest:request error:&error];
if (results == nil) {
    // This implies an error has occurred.
    NSLog(@"Error from Core Data: %@", error);
} else {
    if (results.count == 0) {
        // No objects saved, create a new one...
        DataModelSupport *entity = [[DataModelSupport alloc]initWithEntity:descriptor insertIntoManagedObjectContext:context];            
        entity.fixed_Model = newDict;
    } else {
        // At least one object saved.  There should be only one
        // so use the first... 
        DataModelSupport *entity = [results firstObject];
        entity.fixed_Model = newDict;
    }
}

为简单起见,我假设 newDict 不为零;适当修改以处理这种情况。