CoreData相关04 多个数据库

CoreData相关04 多个数据库,第1张

多个数据库

一般来说你可以把所有的表都放在一个数据库里,但那样不容易管理。我们更多的情况是,针对不同的模型来设计数据库。

在上一个案例中,已经有一个含有Person与Country两个表的数据库,现在我们再新增一个数据库为School。

现在的情况相当于我们有两个数据库了,所以我们创建上下文的方式也需要做一些改变,不然的话,就有可能会出现student表放在别的数据库的情况。
代码的这个位置如果传入的是nil的话,那么就会将所有的的文件都关联到同一个model中,这就会出现student表和person、country表都在一个数据库的情况了。

所以我们要遵循:

一个数据库文件对应一个上下文context

所以我们应对两个模型文件(数据库)就要两个上下文(context)

PS:我现在使用的是XCode13,创建完新的CoreData文件后,编译会有个错误,提示:Value for SWIFT_VERSION cannot be empty

在build Setting配置文件中也没有找到Swift版本号的相关设置。于是百度了一下后,发现不少人都遇到这个问题,原来新创建的CoreData文件默认使用的是Swift

//CoreData__1上下文
@property(nonatomic,strong)NSManagedObjectContext* context;
//SchoolCoreData上下文
@property(nonatomic,strong)NSManagedObjectContext* schoolContext;
- (NSManagedObjectContext*)creatCoreDataContextWithModelName:(NSString*)modelName{

    NSManagedObjectContext* context = [[NSManagedObjectContext alloc]init];
    NSURL* modelURL = [[NSBundle mainBundle]URLForResource:modelName withExtension:@"momd"];
    NSManagedObjectModel* model = [[NSManagedObjectModel alloc]initWithContentsOfURL:modelURL];
    NSPersistentStoreCoordinator* store = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];
    NSError* error = nil;
    NSString* doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
    NSString* sqlitePath = [doc stringByAppendingFormat:@"/%@.sqlite",modelName];
    NSLog(@"%@数据库位置:%@",modelName,sqlitePath);
    NSURL* sqlURL = [NSURL fileURLWithPath:sqlitePath];
    [store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:sqlURL options:nil error:&error];
    context.persistentStoreCoordinator = store;
    return context;
}

这样就能分别使用不同的上下文 *** 作数据库了。

然后其对数据库的 *** 作和单个数据库的 *** 作是一样的,回看之前的相关文章即可。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/994334.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存