多个数据库
一般来说你可以把所有的表都放在一个数据库里,但那样不容易管理。我们更多的情况是,针对不同的模型来设计数据库。
在上一个案例中,已经有一个含有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
@property(nonatomic,strong)NSManagedObjectContext* context;
@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;
}
这样就能分别使用不同的上下文操作数据库了。
然后其对数据库的操作和单个数据库的操作是一样的,回看之前的相关文章即可。
|