【CoreData】多个数据库使用
// 1.创建模型文件 (相当于一个数据库里的表)
// New File ———— CoreData ———— Data Model ———— Next
// 2.添加实体 (相当于一张表)
// 找到我们创建的模型文件(xxx.xcdatamodeld,我创建的叫School.xcdatamodeld)————Add
Entity ———— 添加表内属性(这边我添加2个属性(name,age))
// 3.创建实体类
// New File ———— CorData ———— NSManagedobject subclass ————Next(记得选择需要关联的表)这样就会自动生成相应的模型
// Educationist创建方式和School一样
创建好模型文件后,我们怎样才能让每个模型文件独立呢?我们可以从上下文入手,因为每个上下文对应一个数据库。
//我们先将上下文的创建方式独立出来,以便以后使用
- (NSManagedObjectContext*)setupContextWithModelName:(NSString*)modelName
{
// 生成上下文关联模型文件生成数据库(关联的时候,如果本地没有数据库文件,CoreData会自己创建)
//
上下文,记得引用CoreData框架
NSManagedObjectContext
*context= [[NSManagedObjectContext alloc]init];
// 上下文关联数据库
NSURL*sqlURL= [[NSBundlemainBundle]URLForResource:modelNamewithExtension:@"momd"];
NSManagedObjectModel
*model= [[NSManagedObjectModel alloc]initWithContentsOfURL:sqlURL];
//持久化存储调度器(持久化:把数据保存在一个文件,而不是放在内存中)
NSPersistentStoreCoordinator
*store= [[NSPersistentStoreCoordinator
alloc]initWithManagedObjectModel:model];
//
告诉CoreData数据库的名字和路径
NSString*doc= [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)lastObject];
NSString*sqliteStr = [NSStringstringWithFormat:@"%@.sqlite",modelName];
NSString*sqlitePath = [doc
stringByAppendingPathComponent:sqliteStr];
[storeaddPersistentStoreWithType:NSSQLiteStoreTypeconfiguration:nilURL:[NSURLfileURLWithPath:sqlitePath]options:nilerror:nil];
context.persistentStoreCoordinator=store;
returncontext;
}
// 然后在需要用到上下文的地方调用此方法就可以了
_schoolContext=[selfsetupContextWithModelName:@"School"];
_educationistContext= [self
setupContextWithModelName:@"Educationist"];
这样数据库就独立出来了,测试一下:
#pragma mark - 添加
- (void)addStudent
{
// 创建一个学生对象
// Student *stu = [[Student alloc] init];
Student*stu=[NSEntityDescriptioninsertNewObjectForEntityForName:@"Student"inManagedObjectContext:_schoolContext];
stu.name=
@"李四";
stu.age=
@1.9;
//
直接保存数据库
[_schoolContext
save:nil];
// 创建一间学校对象
School*sch= [NSEntityDescriptioninsertNewObjectForEntityForName:@"School"inManagedObjectContext:_educationistContext];
sch.name=
@"张三中学";
sch.no=
@1.0;
//
直接保存数据库
[_educationistContext
save:nil];
}
#pragma mark - 读取
- (void)readStudent
{
// FectchRequest
抓取请求对象
NSFetchRequest
*request= [NSFetchRequest fetchRequestWithEntityName:@"Student"];
//
执行请求
NSArray*stus = [_schoolContextexecuteFetchRequest:requesterror:nil];
for(Student*stu
instus)
{
NSLog(@"名字:%@身高:%@",stu.name,stu.age);
}
// FectchRequest
抓取请求对象
NSFetchRequest
*request2= [NSFetchRequest fetchRequestWithEntityName:@"School"];
//
执行请求
NSArray*schs = [_educationistContextexecuteFetchRequest:request2error:nil];
for(School*sch
inschs) {
NSLog(@"学校名称:%@编号:%@",sch.name,sch.no);
}
}
2015-10-30 12:20:20.632 CoreData多个数据库使用[1727:66199]名字:李四
身高:1.9
2015-10-30 12:20:20.632 CoreData多个数据库使用[1727:66199]学校名称:张三中学
编号:1
就是这么简单,到这里CoreData简单的使用就结束了!
CoreData的底层就是帮我们把sql语句进行封装,使我们可以避免使用sql语句,更好地进行开发,但肯定是在牺牲运行效率的情况下。
如果需要查看CoreData运行过程中帮我们写了哪些sql语句,可以使用这个方法:
1.打开Product ———— EditScheme… ————Arguments ———— 在ArgumentsPassed OnLaunch中添加两项(顺序不可变)
1>-com.apple.CoreData.SQLDebug
2> 1
这样再次运行APP就会在控制台输出CoreData运行过程中使用的sql语句。
【CoreData】多个数据库使用的更多相关文章
- iOS CoreData版本升级和数据库迁移
app中使用了CoreData,并且在下一个版本中有实体变动,比如实体新增字段.修改字段等改动, 那么app在覆盖安装时就要进行数据库迁移, 否则app就会crash. 那如何实现数据库迁移呢?大概需 ...
- 优于CoreData的Realm数据库基础教程
Realm 是一个跨平台的移动数据库引擎,于 2014 年 7 月发布,准确来说,它是专门为移动应用所设计的数据持久化解决方案之一. Realm 可以轻松地移植到您的项目当中,并且绝大部分常用的功能( ...
- iOS - CoreData 数据库存储
1.CoreData 数据库 CoreData 是 iOS SDK 里的一个很强大的框架,允许程序员以面向对象的方式储存和管理数据.使用 CoreData 框架,程序员可以很轻松有效地通过面向对象的接 ...
- CoreData 数据库
封装CoreManager类 @implementation CoreDataManager { //上下文 NSManagedObjectContext *_ctx; } //单例 +(instan ...
- IOS数据存储之FMDB数据库
前言: 最近几天一直在折腾数据库存储,之前文章(http://www.cnblogs.com/whoislcj/p/5485959.html)介绍了Sqlite 数据库,SQLite是一种小型的轻量级 ...
- IOS中CoreData浅析
CoreData简介: 什么是CoreData? Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中, ...
- CoreData基础
CoreData用于做数据持久化,适合大数据量的存储和查询 CoreData不是数据库 CoreData可以使用数据库 ,XML等方式来存储数据 CoreData使用面向对象的方式操作数据 CoreD ...
- 高级UIKit-05(CoreData)
[day06_1_CoreDataPerson]:保存person对象到coreData数据库 保存大量数据时用CoreData保存到数据库,数据库会存在documents目录下 操作步骤: 1.创建 ...
- CoreData归纳使用
1.CoreData简介 2.CoreData数据模型 3.CoreData的主要对象 4.使用CoreData实现数据存储 一.CoreData简介 CoreData用做数据持久化,是数据持久化的最 ...
随机推荐
- Elasticsearch——使用_cat查看Elasticsearch状态
Elasticsearch通过使用JSON来作为沟通的数据格式,这对于开发者来说很友好,因为很多程序都支持JSON格式.比如js就不说了,Java也有fastjson,ruby什么的都自带json. ...
- Elasticsearch聚合 之 DateRange日期范围聚合
相比于range聚合,date range就是范围可以由时间来指定. 例如: { "aggs":{ "range":{ "date_range&quo ...
- 浅谈Dictionary用法
一.基础篇 1.Dictionary泛型类提供了从一组键到一组值的映射,即键和值的集合类. 2.Dictionary通过键来检索值的速度是非常快的,这是因为 Dictionary 类是作为一个哈希表来 ...
- C# 委托和事件(二):使用.Net框架中的EventArgs和EventHandler
前面一篇里提到事件是通过委托来进行关联的,而委托是可以带各种各样的参数的,其中就可以用事件参数(EventArgs),同时,也可以用.Net框架里边提供的一个委托EventHandler来Handle ...
- C# 如何调用WebServer函数
WebServer(ASMX)服务程序网站的编写简单总结. WebServer中遇到的问题 编写WebServer程序VS运行调试时如果出现 System.Data.OracleClient.Orac ...
- ROW_NUMBER、RANK()、DENSE_RANK()和OVER的使用
/*以FoodPrice列排序并显示排序后的行号*/ SELECT ROW_NUMBER() OVER(ORDER BY FoodPrice DESC) AS RowId,* FROM dbo.Foo ...
- Python 3 利用 subprocess 实现管道( pipe )交互操作读/写通信
这里我们用Windows下的shell来举例: from subprocess import * #因为是举例,就全部导入了 为了方便你理解,我们用一个很简单的一段代码来说明: 可以看见我们利用Pop ...
- LGLTagsView
做项目的时候经常会用到标签,比如说现在很多项目中搜索历史用标签展示 和 选择某个产品的不同属性用标签展示....网上的有很多封装好的标签,但是作为一个上进的程序员,都希望能有一个自己写的.其实也是一种 ...
- MyBatis自动生成代码示例
在项目中使用到mybatis时,都会选择自动生成实体类,Mapper,SqlMap这三个东东. 手头上在用的又不方便,找了下网上,其实有很多文章,但有些引用外部文件时不成功,也不方便,所以重新整理了下 ...
- GJM : Python简单爬虫入门(二) [转载]
感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...