神奇的记录,多种配置和Restkit

时间:2014-07-11 17:10:07

标签: ios core-data restkit magicalrecord

我在一个相当大的IOS项目中使用魔法记录。我使用配置将大型种子数据库与用户数据分开。由于Magical Record不支持配置,我解构了Magical Record的setupCoreDataStackWithAutoMigratingSqliteStoreNamed方法并将其替换为以下内容:

+(void) RB_setupMultipleStores:(NSString *) seedStoreName userStore:(NSString *) userStoreName
/* change persistent store to one with multiple configurations. Assumes Magical Record is initialized to perform auto migration. */   
{        
NSError * error= nil;

[MagicalRecord cleanUp];  //Tear down Magical Record

NSManagedObjectModel * model = [NSManagedObjectModel MR_defaultManagedObjectModel];

NSURL *seedURL = [NSPersistentStore MR_urlForStoreName:[seedStoreName stringByAppendingString:@".sqlite"]];

NSPersistentStoreCoordinator * coordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];

NSDictionary *options = [NSDictionary dictionaryWithObjectsAndKeys:
                         [NSNumber numberWithBool:YES], NSMigratePersistentStoresAutomaticallyOption,
                         [NSNumber numberWithBool:YES], NSInferMappingModelAutomaticallyOption,
                         nil];

NSPersistentStore * seedStore =[coordinator
                                            addPersistentStoreWithType:NSSQLiteStoreType
                                                         configuration:@"Seed"
                                                                   URL:seedURL
                                                               options:options
                                                                 error:&error];
if (!seedStore || error)
{
    NSLog(@"Error setting up seed store:%@ for %@", [error localizedDescription], seedURL);
    exit(-1);
}

NSURL *userURL = [NSURL URLForDocumentDirectoryWithAppendedPath:[userStoreName stringByAppendingString:@".sqlite"]];

NSPersistentStore * userStore = [coordinator
                                 addPersistentStoreWithType:NSSQLiteStoreType
                                                          configuration:@"User"
                                                                    URL:userURL
                                                                options:options
                                                                  error:&error];

if (!userStore || error)
{
    NSLog(@"Error setting up user store:%@ for %@", [error localizedDescription], userURL);
    exit (-1);
}
[NSPersistentStoreCoordinator MR_setDefaultStoreCoordinator:coordinator];

//Bring back Magical Record with updated coordinator.

[NSManagedObjectContext MR_initializeDefaultContextWithCoordinator:coordinator];

[[NSManagedObjectContext MR_defaultContext] setUndoManager:nil];
}

现在我将添加Restkit。我需要共享对象模型和持久存储,我宁愿使用一组上下文而不是两个不同的堆栈。

我看到了五种可能的方法:

  1. 修改https://github.com/blakewatters/RKMagicalRecord以支持多种配置。这看起来微不足道,但它需要我使用一个类别来表示一些私有方法,而优秀的MR开发人员建议不要明确设置MR默认和root保存上下文。

  2. 首先创建Magical Record上下文,然后将它们分配给Restkit。这甚至会起作用吗?它有意义吗?

  3. 从同一个NSPersistentStoreCoordinator初始化Restkit和Magical Record。这有意义吗?

  4. 使用不同但相似的NSPersistentStoreCoordinators创建两个单独的堆栈。

  5. 创建我自己的堆栈和上下文,并使用这些上下文调用Restkit和MR。

  6. 任何人都可以推荐这些或任何其他方法吗?每个都需要付出巨大努力来进行测试我即将走下第一条道路。

    ...谢谢

1 个答案:

答案 0 :(得分:4)

从根本上说,CoreData已经有办法解决这个问题。您可以让多个协调器指向同一个商店,或者您的方案。由每个框架决定是否允许您使用框架本身无法创建或设置的堆栈。

MagicalRecord归结为一组用于获取和保存的辅助方法。您不需要使用任何MagicalRecord的设置方法来实现其提取的魔力。设置方法可以帮助您更快地开展新项目,并为您在主线程/队列上执行提取时使用的“默认”上下文提供单一访问点。对于所有其他用途,每次都使用显式的inContext:参数。使用该参数,您可以使用您想要的任何MOC,一切都会起作用。这是设计的。从来没有写过MagicalRecord来取代CoreData。编写它是为了简化任务。

有了这个,你就可以让RestKit处理你的整个CoreData堆栈并仅使用MagicalRecord来获取用于获取和保存的便利API。这样可以节省您必须执行任何这些解决方案,并回过头来解决您的应用特定问题......