CoreData 学习之路
来源:互联网 发布:英文搜题软件 编辑:程序博客网 时间:2024/06/15 08:32
Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象。在此数据操作期间,我们不需要编写任何SQL语句,这个有点类似于著名的Hibernate持久化框架,不过功能肯定是没有Hibernate强大的。简单地用下图描述下它的作用:
左边是关系模型,即数据库,数据库里面有张person表,person表里面有id、name、age三个字段,而且有2条记录;
右边是对象模型,可以看到,有2个OC对象;
利用Core Data框架,我们就可以轻松地将数据库里面的2条记录转换成2个OC对象,也可以轻松地将2个OC对象保存到数据库中,变成2条表记录,而且不用写一条SQL语句。
模型文件
![abc](http://img.my.csdn.net/uploads/201302/01/1359707024_5895.png)
Person实体中有:name(姓名)、age(年龄)、card(身份证)三个属性
Card实体中有:no(号码)、person(人)两个属性
1.选择模板
![abc](http://img.my.csdn.net/uploads/201302/01/1359707426_5763.png)
![abc](http://img.my.csdn.net/uploads/201302/01/1359707501_8695.png)
2.添加实体
![](http://img.my.csdn.net/uploads/201302/01/1359707563_9302.png)
![](http://img.my.csdn.net/uploads/201302/01/1359707773_7614.png)
4.添加Card的1个基本属性
![](http://img.my.csdn.net/uploads/201302/01/1359707796_4561.png)
右图中的表示Card中有个Person类型的person属性,目的就是建立Card跟Person之间的一对一关联关系(建议补上这一项),在Person中加上Inverse属性后,你会发现Card中Inverse属性也自动补上了
了解NSManagedObject
![](http://img.my.csdn.net/uploads/201302/01/1359708744_9527.png)
![](http://img.my.csdn.net/uploads/201302/01/1359708756_9809.png)
1> setValue:forKey:存储属性值(属性名为key)
CoreData中的核心对象
![](http://img.my.csdn.net/uploads/201302/01/1359708878_8041.png)
注:黑色表示类名,红色表示类里面的一个属性
开发步骤总结:
1.初始化NSManagedObjectModel对象,加载模型文件,读取app中的所有实体信息
2.初始化NSPersistentStoreCoordinator对象,添加持久化库(这里采取SQLite数据库)
3.初始化NSManagedObjectContext对象,拿到这个上下文对象操作实体,进行CRUD操作
代码实现
导入#import<CoreData/CoreData.h>
贴代码之前需要了解6个对象:
1、NSManagedObjectContext
管理对象,上下文,持久性存储模型对象
2、NSManagedObjectModel
被管理的数据模型,数据结构
3、NSPersistentStoreCoordinator
连接数据库的
4、NSManagedObject
被管理的数据记录
5、NSFetchRequest
数据请求
6、NSEntityDescription
表格实体结构
此外还需要知道.xcdatamodel文件编译后为.momd或者.mom文件
#pragma mark - CoreData Stack- (NSManagedObjectContext *)managedObjectContext{ if (_managedObjectContext) { return _managedObjectContext; } NSPersistentStoreCoordinator * coordinator = [self persistentStoreCoordinator]; if (coordinator) { _managedObjectContext = [[NSManagedObjectContext alloc] init]; // 初始化上下文,设置persistentStoreCoordinator属性 [_managedObjectContext setPersistentStoreCoordinator:coordinator]; } return _managedObjectContext;}-(NSPersistentStoreCoordinator *)persistentStoreCoordinator{ if (_persistentStoreCoordinator) { return _persistentStoreCoordinator; } // 构建SQLite数据库文件的路径 NSURL * storeUrl = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"NewsModel.sqlite"]; NSError * error = nil; // 传入模型对象,初始化NSPersistentStoreCoordinator _persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:[self managedObjectModel]]; // 添加持久化存储库,这里使用SQLite作为存储库 if ([_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeUrl options:nil error:&error]) { return nil; } return _persistentStoreCoordinator;}//从应用程序包中加载模型文件。.xcdatamodel(模型文件)文件编译后为.momd或者.mom文件-(NSManagedObjectModel *)managedObjectModel{ if (_managedObjectModel) { return _managedObjectModel; } NSURL * modelUrl = [[NSBundle mainBundle]URLForResource:@"NewsModel" withExtension:@"momd"]; _managedObjectModel = [[NSManagedObjectModel alloc]initWithContentsOfURL:modelUrl]; return _managedObjectModel;}- (NSURL *)applicationDocumentsDirectory{ return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];}
2.增删改查操作。
//插入数据- (void)insertCoreData:(NSMutableArray *)dataArray{ NSManagedObjectContext * context = [self managedObjectContext]; for (News * info in dataArray) { //此处添加到的表为News这个实体 News * newsInfo = [NSEntityDescription insertNewObjectForEntityForName:NewsTableName inManagedObjectContext:context]; newsInfo.newsid = info.newsid; newsInfo.title = info.title; newsInfo.imgurl = info.imgurl; newsInfo.descr = info.descr; newsInfo.islook = info.islook; NSError *error; if (![context save:&error]) { NSLog(@"%@",error.localizedDescription); } }}//查询.- (NSMutableArray *)selectData:(int)pageSize andOffset:(int)currentPage{ NSManagedObjectContext * context = [self managedObjectContext]; //限定查询结果的数量 //selFetchLimit //查询的偏移量 //setFetchOffset NSFetchRequest * fetchRequest = [[NSFetchRequest alloc]init]; [fetchRequest setFetchLimit:pageSize]; [fetchRequest setFetchOffset:currentPage]; //此处添加到的表为News这个实体 NSEntityDescription * entity = [NSEntityDescription entityForName:NewsTableName inManagedObjectContext:context]; [fetchRequest setEntity:entity]; NSError * error; NSArray * fetchedObjects = [context executeFetchRequest:fetchRequest error:&error]; NSMutableArray * resultArray = [NSMutableArray array]; for (News * info in fetchedObjects) { [resultArray addObject:info]; } return resultArray;}//删除操作- (void)deleteData{ NSManagedObjectContext * context = [self managedObjectContext]; //此处添加到的表为News这个实体 NSEntityDescription * entity = [NSEntityDescription entityForName:NewsTableName inManagedObjectContext:context]; NSFetchRequest * fetchRequest = [[NSFetchRequest alloc]init]; [fetchRequest setIncludesPropertyValues:NO]; [fetchRequest setEntity:entity]; NSError * error; NSArray * datas = [context executeFetchRequest:fetchRequest error:&error]; if (!error && datas && [datas count]) { for (NSManagedObject * obj in datas) { [context deleteObject:obj]; } } if (![context save:&error]) { NSLog(@"%@",error.localizedDescription); }}//更新- (void)updateData:(NSString *)newsId withIsLook:(NSString *)isLook{ NSManagedObjectContext * context = [self managedObjectContext]; NSPredicate * predicate = [NSPredicate predicateWithFormat:@"newsid like[cd] %@",newsId]; //https://developer.apple.com/library/mac/#documentation/Cocoa/Conceptual/Predicates/Articles/pCreating.html //首先还是需要建立一个request NSFetchRequest * request = [[NSFetchRequest alloc]init]; [request setEntity:[NSEntityDescription entityForName:newsId inManagedObjectContext:context]]; [request setPredicate:predicate]; NSError * error = nil; NSArray * result = [context executeFetchRequest:request error:&error]; for (News * info in result) { info.islook = isLook; } //保存 if (![context save:&error]) { NSLog(@"%@",error.localizedDescription); }}
- (id)initWithStoreURL:(NSURL*)storeURL modelURL:(NSURL*)modelURL{ self = [super init]; if (self) { self.storeURL = storeURL; self.modelURL = modelURL; [self setupManagedObjectContexts]; } return self;}- (void)setupManagedObjectContexts{ self.managedObjectContext = [self setupManagedObjectContextWithConcurrencyType:NSMainQueueConcurrencyType]; self.managedObjectContext.undoManager = [[NSUndoManager alloc] init]; self.backgroundManagedObjectContext = [self setupManagedObjectContextWithConcurrencyType:NSPrivateQueueConcurrencyType]; self.backgroundManagedObjectContext.undoManager = nil; [[NSNotificationCenter defaultCenter] addObserverForName:NSManagedObjectContextDidSaveNotification object:nil queue:nil usingBlock:^(NSNotification* note) { NSManagedObjectContext *moc = self.managedObjectContext; if (note.object != moc) { [moc performBlock:^(){ [moc mergeChangesFromContextDidSaveNotification:note]; }]; } }];}- (NSManagedObjectContext *)setupManagedObjectContextWithConcurrencyType:(NSManagedObjectContextConcurrencyType)concurrencyType{ NSManagedObjectContext *managedObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:concurrencyType]; managedObjectContext.persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:self.managedObjectModel]; NSError* error; [managedObjectContext.persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:self.storeURL options:nil error:&error]; if (error) { NSLog(@"error: %@", error.localizedDescription); NSLog(@"rm \"%@\"", self.storeURL.path); } return managedObjectContext;}- (NSManagedObjectModel*)managedObjectModel{ return [[NSManagedObjectModel alloc] initWithContentsOfURL:self.modelURL];}然后我们调用这个方法两次,一次是为主 managed object context,一次是为后台 managed object context:
self.managedObjectContext = [self setupManagedObjectContextWithConcurrencyType:NSMainQueueConcurrencyType]; self.managedObjectContext.undoManager = [[NSUndoManager alloc] init]; self.backgroundManagedObjectContext = [self setupManagedObjectContextWithConcurrencyType:NSPrivateQueueConcurrencyType]; self.backgroundManagedObjectContext.undoManager = nil;注意传递的参数 NSPrivateQueueConcurrencyType 告诉 Core Data 创建一个独立队列,这将确保后台 managed object context 的运行发生在一个独立的线程中。
[[NSNotificationCenter defaultCenter] addObserverForName:NSManagedObjectContextDidSaveNotification object:nil queue:nil usingBlock:^(NSNotification* note) { NSManagedObjectContext *moc = self.managedObjectContext; if (note.object != moc) { [moc performBlock:^(){ [moc mergeChangesFromContextDidSaveNotification:note]; }]; } }];
本文出自于csdn上的博客,感谢他们的付出,节约了很多时间!
- CoreData 学习之路
- iOS之学习CoreData的笔记
- iOS之CoreData学习(一)
- CoreData学习
- coreData学习
- IOS成长之路-CoreData详细介绍
- IOS成长之路-CoreData基础
- IOS成长之路-CoreData使用
- XMPP框架 微信项目开发之CoreData学习——CoreData的基本使用
- iOS学习之CoreData的增删改查
- iOS学习之CoreData多表关联使用
- CoreData实例分析学习
- CoreData学习笔记
- CoreData实例分析学习
- CoreData学习记录一
- CoreData学习笔记
- CoreData的学习记录
- CoreData学习笔记
- C++模板 静态成员 定义(实例化)
- java通过ftp上传、下载文件,遍历文件目录
- Android MarginLeft与MarginStart的区别
- const 用于类中--Thinking In C++
- 谷歌地图 DEMO
- CoreData 学习之路
- dojo中gridContainer使用时的注意事项
- 1.3(1)
- Oracle查询每个表占用空间大小
- HTML5资料小结
- uiautomation之AccessibilityNodeInfo
- [G+smo]gsMFunctionExpr
- netstat用法记录
- php发送邮件