IOS-Coredata 核心数据库的基础使用
2016-04-21 10:44
399 查看
demo资源链接
Command + N打开新建文件窗口,选择Core Data目录中的Data Model然后Next
2.创建模型实体
这里创建了一个名叫People的实例数据库,里面有两个字段age和name分别是整型和字符串类型的
新建一个继承与NSObjcet的类,创建一个NSManagedObjectContext属性,命名为ManagedObjectContext
2.为数据库添加一条数据
3.查询数据,数据排序
4.修改数据
5.删除一条数据
注:在使用context保存之前所做的更改如:创建新的对象,删除对象,修改对象属性,一样会影响FetchRequest查找到的数据,但是不会影响本地储存的数据,[context save]方法的作用是将程序内存中所有的数据库数据同步储存到本地.可以使用[context hasChange]方法来判断本地数据和内存中的数据是否一致.
功能介绍
CoreData核心数据库,是cocoa框架中得一个用于管理数据库和对象之间映射关系的一套支持库,它主要提供ORM(对象关系映射)功能,可以将OC对象转化为数据,保存在本地数据库也可以将数据库中的数据还原成OC对象,极大的简化了操作.CoreData不仅支持SQLite数据库还支持XML,内存和二进制文件的储存库文件
CoreData.framework涉及类
类名 | 所属库 | 功能 |
---|---|---|
NSManaged Object Model | CoreData | 描述应用程序的数据模型,这个模型包含实体(Entity),特性(Property),读取请求 |
NSManaged Object Context | CoreData | 参与对数据对象进行操作的全过程,并检测数据对象的变化,以提供对undo/redo的支持及更新绑 定到数据的UI. |
NSManaged Object | CoreData | 数据对象,用于储存从数据库获得的数据,与ManagedObjectContext关联. |
NSPersisterStore Coordinator | CoreDara | 数据文件管理器,用于处理对数据库的增删改查操作.一般不需要对这个类进行操作. |
NSEntityDescription | CoreData | 表实体结构,管理表的结构,从表结构中创建实体类 |
NSSortDescriptor | Foundation | 负责管理查询数据时,数据的排列方式 |
NSFetchRequest | CoreData | 查询结果集,主要用于查询数据,并返回结果,可以设置查询条件和查询顺序 |
NSPredicate | Foundation | 谓词条件,使用谓词来为FetchRuquest设置查询条件 |
创建数据库模型文件
1.选择模板Command + N打开新建文件窗口,选择Core Data目录中的Data Model然后Next
2.创建模型实体
这里创建了一个名叫People的实例数据库,里面有两个字段age和name分别是整型和字符串类型的
使用代码对数据库进行操作
1.编写代码创建上下文新建一个继承与NSObjcet的类,创建一个NSManagedObjectContext属性,命名为ManagedObjectContext
- (instancetype)init{ self = [super init]; if (self) { //获取数据库模型的本地url Model.xcdatamodeld编译后的后缀为momd; NSURL * modelUrl = [[NSBundle mainBundle] URLForResource:@"Model" withExtension:@"momd"]; //创建模型对象,从数据库模型中创建对象 NSManagedObjectModel * model = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelUrl]; //创建文件管理器管理模型对象. NSPersistentStoreCoordinator * store = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model]; //设置数据库文件保存的路径,后缀为sqlite NSURL * dataURL = [[[[NSFileManager defaultManager]URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject]URLByAppendingPathComponent:@"mySQL.sqlite"]; NSError * error = nil; //生成本地数据库文件,并设置生成文件的类型为SQLite [store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:dataURL options:nil error:&error]; if (error) { NSLog(@"创建数据库失败!"); abort(); }else{ //生成文件成功,创建用于操作数据库的上下文 _managerObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType]; //设置上下文操作的数据库管理器,不需要直接操作PersistentStoreCoordinator,我们只要操作上下文就可以对数据库进行增删改查. [_managerObjectContext setPersistentStoreCoordinator:store]; } } return self; }
2.为数据库添加一条数据
//增 - (void)addPeopleObjectWithPeopleName:(NSString *)name peopleAge:(NSNumber *)age{ //根据People实体模型创建一个新的People对象,并加入上下文管理 NSManagedObject * people = [NSEntityDescription insertNewObjectForEntityForName:@"People" inManagedObjectContext:_managerObjectContext]; //设置people的属性 [people setValue:name forKey:@"name"]; [people setValue:age forKey:@"age"]; //同步数据到本地数据库.这里要注意下,即使没有保存到本地,依然能查找到这个条目,只不过APP下次运行就没有了. if([_managerObjectContext save:nil]){ NSLog(@"保存数据成功!"); } }
3.查询数据,数据排序
//按照年龄排序并查找年龄小于1的条目 - (NSArray *)sortPeopleWithAge{ //创建一个结果集 NSFetchRequest * request = [[NSFetchRequest alloc] init]; //设置结果集所对应的实体和上下文,这里表示查询People实体内的数据, 这里的People要和模型文件中得实体名称相同 request.entity = [NSEntityDescription entityForName:@"People" inManagedObjectContext:_managerObjectContext]; //创建一个排序规则,按照age进行升序排列 NSSortDescriptor * sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:YES]; //可以添加多个排序规则 request.sortDescriptors = @[sort]; //添加谓词,为查找指定条件为 age属性大于1的条目 NSPredicate * predicate = [NSPredicate predicateWithFormat:@"age > 1"]; request.predicate = predicate; //获取查找结果 NSArray * array = [_managerObjectContext executeFetchRequest:request error:nil]; return array; }
4.修改数据
//改 - (NSManagedObject *)updatePeopleName:(NSString *)name toNewName:(NSString *)newName{ //查找要修改的数据条目 NSManagedObject * people = [self peopleObjectWithName:name]; //修改属性 [people setValue:newName forKey:@"name"]; //同步保存到本地数据库 [_managerObjectContext save:nil]; return people; }
5.删除一条数据
//删 - (void)deletePeopleObjectWithName:(NSString *)name{ //查找要删除的数据条目 NSManagedObject * people = [self peopleObjectWithName:name]; //删除条目 [_managerObjectContext deleteObject:people]; //同步保存到本地数据库 if([_managerObjectContext save:nil]){ NSLog(@"删除成功!"); } }
注:在使用context保存之前所做的更改如:创建新的对象,删除对象,修改对象属性,一样会影响FetchRequest查找到的数据,但是不会影响本地储存的数据,[context save]方法的作用是将程序内存中所有的数据库数据同步储存到本地.可以使用[context hasChange]方法来判断本地数据和内存中的数据是否一致.
相关文章推荐
- 验证mongodb副本集并实现自动切换primary~记录过程
- ORACLE 11G R2 DG BROKER 基础
- Mysql 实现篮球比赛赛程中两支队伍的查询
- Memcached
- Oracle存储过程详解(四)-ibatis中调用
- sql
- ORACLE 11G分区表新功能:列表--范围分区
- oracle复制一张表结构到另外一张新表中
- mysql绑定多个ip地址
- 两种方法解决Oracle的数值0.5只显示成.5问题
- postgresql数据库对象管理之非模式对象
- 编译安装和二进制安装mysql
- mysql同一张表的字段更新到另一张表的字段
- weblogic堆积的数据库链接2
- PostgreSQL之树形展示
- PLSQL Developer激活码
- Oracle字符集和国家字符集
- Understanding and Using HRMS Security in Oracle HRMS
- redis实战
- redis实战