1.在工程中添加build Phases的Link Binary with Libraries下添加CoreData的库。

2.在当前工程中新建文件选择CoreData——>DataModel,新建一个数据模型,往该模型中添加实体Entity,entity就是对应sqlite里面的表,一个实体对应一张表,有多个表就添加多个实体,然后往实体里面添加属性attributes,attributes就是sqlite表中的列。

3.在当前工程下右键新建CoreData ——>NSManageObject subclass,xcode会让你选择要生成的NSManageObjct subclass 的数据模型和实体,也就是说要生成对象模型所对应的数据库和表,添加完成后,新生成的对象模型里面有@dynamic 标记的对象,这是说对象的setter和getter方法由手动完成。

4.在使用CoreData的源文件中添加头

#import <CoreData/CoreData.h>

5.CoreData使用需要用到三个对象:

(1).NSManagedObjectContext

(2).NSManagedObjectModel

(3).NSPersistentStoreCoordinator

NSManagedObjectContext是进行数据持久化时的上下文,NSManagedObjectContext初始化时需要指定:NSPersistentStoreCoordinator

NSPersistentStoreCoordinator是数据持久化的助手,初始化时需要指定数据持久化时用到的数据存储类型:sqlite、xml、内存。还指定路径和NSManagedObjectModel

NSManagedObjectModel是对象模型

6.在源文件中添加三个属性:

@property ( strong , nonatomic) NSManagedObjectContext * coreDataContext;
@property ( strong , nonatomic) NSManagedObjectModel * coreDataModel;
@property ( strong , nonatomic) NSPersistentStoreCoordinator * coreDataPersistent;

并且进行延迟加载初始化:

-(NSManagedObjectModel *) coreDataModel
{
if (_coreDataModel ==nil ) {
_coreDataModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:[[NSBundle mainBundle] URLForResource:@"resultsModel" withExtension:@"momd"]];
}
return _coreDataModel;
}
-(NSPersistentStoreCoordinator *)coreDataPersistent
{
if (_coreDataPersistent==nil) {
_coreDataPersistent = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self coreDataModel]];
NSString * path = [NSSearchPathForDirectoriesInDomains(NSDocumentationDirectory, NSUserDomainMask, YES) lastObject];
NSURL * pathURL = [NSURL fileURLWithPath:[path stringByAppendingString:@"resultsModel.sqlite" ]];
NSError * error = nil;
NSPersistentStore * store = [ _coreDataPersistent addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:pathURL options:nil error:&error] ;
if (!store) {
[NSException raise:@"add database error" format:@"%@" ,[error localizedDescription]];
}
}
return _coreDataPersistent ;
} -(NSManagedObjectContext *) coreDataContext
{
if(_coreDataContext ==nil)
{
_coreDataContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
[_coreDataContext setPersistentStoreCoordinator:[self coreDataPersistent]];
}
return _coreDataContext;
}

NSManagedObjectModel需要指定对象模型xxx.momd这个是新建的CoreData:xxx.xcdatamodeld自动在bundle下生成的。

插入数据:

 Results * insertResult = [NSEntityDescription insertNewObjectForEntityForName:@"Results" inManagedObjectContext: [self  coreDataContext]];
insertResult.in = @"123";
insertResult.re = @"ok";
insertResult.reD = @"1";
NSDateFormatter * dateFormatter = [[NSDateFormatter alloc] init];
[dateFormatter setDateFormat:@"YYYY-MM-dd hh:mm:ss"];
insertResult.Time = [dateFormatter stringFromDate:[NSDate date]];
NSError * error = nil;
if(![[self coreDataContext] save: &error])
{
[NSException raise:@"save data to database error:" format:@"%@",[error localizedDescription]];
}

这里的in .re .reD .Time 分别对应实体Results里面的属性in .re .reD .Time 对它们赋值后调用 [context save:&error] 就直接保存到数据库中。

读取数据:

 NSFetchRequest * databaseFecth = [[NSFetchRequest alloc] init];
databaseFecth.entity = [NSEntityDescription entityForName:@"Results" inManagedObjectContext:[self coreDataContext]]; NSArray * objs = [[self coreDataContext] executeFetchRequest:databaseFecth error:&error];
if(error)
{
[NSException raise:@"fetch data from database error:" format:@"%@",[error localizedDescription]];
}
for (NSManagedObject * obj in objs) {
NSLog(@"%@", obj); }

需要注意的是如果直接使用_context而不是[self context] 来获取当前对象模型的上下文则会在运行时出错:

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '+entityForName: nil is not a legal NSManagedObjectContext parameter searching for entity name 'Results''

因为直接使用_context时是nil的,只有调用才不会为nil

ios开发之CoreData使用的更多相关文章

  1. iOS开发之CoreData数据存储

    iOS开发之CoreData数据存储 参考资料:https://developer.apple.com/library/ios/documentation/Cocoa/Conceptual/CoreD ...

  2. iOS开发之Socket通信实战--Request请求数据包编码模块

    实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...

  3. iOS开发之UISearchBar初探

    iOS开发之UISearchBar初探 UISearchBar也是iOS开发常用控件之一,点进去看看里面的属性barStyle.text.placeholder等等.但是这些属性显然不足矣满足我们的开 ...

  4. iOS开发之UIImage等比缩放

    iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...

  5. iOS开发之 Xcode6 添加xib文件,去掉storyboard的hello world应用

    iOS开发之  Xcode6.1创建仅xib文件,无storyboard的hello world应用 由于Xcode6之后,默认创建storyboard而非xib文件,而作为初学,了解xib的加载原理 ...

  6. iOS开发之loadView、viewDidLoad及viewDidUnload的关系

    iOS开发之loadView.viewDidLoad及viewDidUnload的关系 iOS开发之loadView.viewDidLoad及viewDidUnload的关系    标题中所说的3个方 ...

  7. iOS开发之info.pist文件和.pch文件

    iOS开发之info.pist文件和.pch文件 如果你是iOS开发初学者,不用过多的关注项目中各个文件的作用.因为iOS开发的学习路线起点不在这里,这些文件只会给你学习带来困扰. 打开一个项目,我们 ...

  8. iOS开发之WKWebView简单使用

    iOS开发之WKWebView简单使用   iOS开发之 WKWebVeiw使用 想用UIWebVeiw做的,但是突然想起来在iOS8中出了一个新的WKWebView,算是UIWebVeiw的升级版. ...

  9. iOS 开发之Block

    iOS 开发之Block 一:什么是Block.Block的作用 UI开发和网络常见功能的实现回调,按钮事件的处理方法是回调方法. 1.     按钮事件 target action 机制. 它是将一 ...

随机推荐

  1. sqlite3之基本操作(一)

    简单的介绍 SQLite数据库是一款非常小巧的嵌入式开源数据库软件,也就是说没有独立的维护进程,所有的维护都来自于程序本身.它是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经 ...

  2. C#6.0语法糖剖析(二)

    1.索引初始化 使用代码 ] = ] = ] = "thirteen"}; 编译器生成的代码 Dictionary<int, string> dictionary2 = ...

  3. 你可以使用 play framework 做5件很爽的事情http://www.anool.net/?p=629

    1.绑定HTTP参数到JAVA方法里的参数. 使用PLAY可以很简单的从JAVA代码中检索HTTP参数.只要把方法参数申明成和HTTP参数相同既可. 比如,这个request: Http代码 /art ...

  4. OSX cordova+Ionic的安装配置

    0.安装前确定你的系统安装了node和xcode 1.cordova (1)安装cordova npm config set registry http://registry.cnpmjs.org s ...

  5. 来自 CORS 预检通道的 CORS 头 'Access-Control-Allow-Headers' 的令牌 'appkey' 无效)。

    1.服务端: web.config文件中: <system.webServer> <httpProtocol> <customHeaders> <add na ...

  6. ABAP 表格控制(Table Control)和步循环

    表格控制(Table Control)和步循环     1.两个标准Demo: SAPMTZ60,SAPMTZ61 2.简介 3.建立Table Control程序的基本流程 4.使用步循环 5.表格 ...

  7. CRM ribbon按钮上引用JS库

    在CRM ribbion 按钮上引用 javascript库文件实验,怎么要引用javascript库文件.实验 加载完ribbbion 按钮后立即执行 引用的库文件 (function(){ ale ...

  8. 详解HTML5中rel属性的prefetch预加载功能使用

    在HTML5中,有个很有用但常被忽略的特性,就是预先加载(prefetch),它的原理是: 利用浏览器的空闲时间去先下载用户指定需要的内容,然后缓存起来,这样用户下次加载时,就直接从缓存中取出来,效率 ...

  9. 桥牌笔记 Skill Level 4 C7 小心将吃

    南主打5H. 看来问题不大,但要小心南的方块AK会阻塞桥路. 如果方块3-2分布,并且将牌也3-2分布,就很容易. 如果红桃4-1分布,那是死定了. 如果方块4-1分布,还有希望完成的! 为了防止东家 ...

  10. Android Http请求框架一:Get 和 Post 请求

    1.HttpUtil package com.app.android01; import java.io.BufferedReader; import java.io.IOException; imp ...