Core Data 学习简单整理01
Core Data是苹果针对Mac和iOS平台开发的一个框架, 通过CoreData可以在本地生成数据库sqlite,提供了ORM的功能,将对象和数据模型相互转换 . 通过Core Data管理和操作. 能够快速达到项目的存储数据的需求.
CoreData优点:能够合理管理内存,避免使用sql的麻烦,高效, 由于是苹果提供的解决方案, 所以不用太过担心会有其他问题. 我的观念就是先使用上了后再考虑其他, 问题有一个就解决一个.
Core Data 默认使用Sqlite. 因此在沙盒Document文件夹中找到.sqlite的数据库文件. 这里记录一个比较好用的快速打开模拟器沙盒路径的工具: https://github.com/opensim/opensim
1.如何使用CoreData
- 创建工程时, 勾选Use Core Data.
- 手动添加, (如何要想向创建时没有选择Use Core Data)
如果不知道该添加什么, 一个比较便捷的方法, 是直接新建一个空白工程, 勾选Use Core Data后, 对比AppDelegate.h中的代码, 然后再将多的内容添加到工程中.
添加Core Data后, 在AppDelegate.h中就有帮我们生成用于管理、存储这些模型的对象,我们可以通过添加AppDelegate头文件来使用.
添加Core Data后, 就是建立数据模型,说到模型, 就要提一下Core Data常用的6个对象:
1、NSManagedObjectContext
管理对象,上下文,持久性存储模型对象
2、NSManagedObjectModel
被管理的数据模型,数据结构
3、NSPersistentStoreCoordinator
连接数据库的
4、NSManagedObject
被管理的数据记录
5、NSFetchRequest
数据请求
6、NSEntityDescription
表格实体结构
此外还需要知道.xcdatamodel文件编译后为.momd或者.mom文件
一 开始
右键添加一个Core data -> Data Model(如果创建工程时, 直接勾选use core data, 会直接默认生成.xcdatamodeld).
选中.xcdatamodeld主要使用到了下列一些东西:
Entity: 实体(我们要生成的模型对象的实体, User, Car, Person等等)
Attributes:实体对象属性
ReaationShips:关系
Fetched Properties:
>_<多表关联内容可以看看: http://www.jianshu.com/p/e9f3b5e0cd19
二. 创建实体管理
右键添加一个Core data -> NSManagedObject subclass, 一直选择, 选中Car, Wheel. 到最后会实现
QQ20151206-1.png
三. 导入AppDelegate.h头文件, 开始管理数据库
主要操作:
//先取出coredata上下文管理者
AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
NSManagedObjectContext context = appDelegate.managedObjectContext;*
//1.保存新数据
Car *car = [NSEntityDescription insertNewObjectForEntityForName: @"Car" inManagedObjectContext: context];
car.carName = label1.text;
car.carType = label2.text;
[appDelegate saveContext];
//2.查询数据
NSError *error;
NSFetchRequest *request = [NSFetchRequest new];
NSEntityDescription *entity = [NSEntityDescription entityForName: @"Car" inManagedObjectContext: context];
[request setEntity: entity];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"carName=%@", carName];
[request setPredicate:predicate];
NSArray *results = [[context executeFetchRequest: request error: &error] copy];
for (Car *car in results) {
NSLog(@"%@", car.carName);
}
//3.更新数据
{
NSFetchRequest* request=[[NSFetchRequest alloc] init];
NSEntityDescription *car=NSEntityDescription entityForName:@"car" inManagedObjectContext:_myAppDelegate.managedObjectContext];
[request setEntity:car];
///查询条件
NSPredicate* predicate=[NSPredicate predicateWithFormat:@"carName==%@",@"name"];
[request setPredicate:predicate];
NSError* error=nil;
NSMutableArray*
mutableFetchResult=[[_myAppDelegate.managedObjectContext
executeFetchRequest:request error:&error] mutableCopy];
if (mutableFetchResult==nil) {
NSLog(@"Error:%@",error);
}
NSLog(@"The count of entry: %i",[mutableFetchResult count]);
for (Car* car in mutableFetchResult) {
car.carName = @"name1" ;
...
}
//更新后要进行保存,否则没更新
[_myAppDelegate.managedObjectContext save:&error];
}
//4.删除数据
{
NSFetchRequest* request=[[NSFetchRequest alloc] init];
NSEntityDescription* car=[NSEntityDescription entityForName:@"Car"
inManagedObjectContext:_myAppDelegate.managedObjectContext];
[request setEntity:car];
NSPredicate* predicate=[NSPredicate predicateWithFormat:@"carName==%@",@"name"];
[request setPredicate:predicate];
NSError* error=nil;
NSMutableArray*
mutableFetchResult=[[_myAppDelegate.managedObjectContext
executeFetchRequest:request error:&error] mutableCopy];
if (mutableFetchResult==nil) {
NSLog(@"Error:%@",error);
}
NSLog(@"The count of entry: %i",[mutableFetchResult count]);
for (Car *car in mutableFetchResult) {
[_myAppDelegate.managedObjectContext deleteObject:car];
}
if ([_myAppDelegate.managedObjectContext save:&error]) {
NSLog(@"Error:%@,%@",error,[error userInfo]);
}
}
- 条件查询的更多内容, 可以查看官方文档:
https://developer.apple.com/library/mac/documentation/Cocoa/Conceptual/Predicates/Articles/pCreating.html
2.NSFetchRequest 常用方法 -setEntity:
设置你要查询的数据对象的类型(Entity)
- -setPredicate:
设置查询条件 - -setFetchLimit:
设置最大查询对象数目 - -setSortDescriptors:
设置查询结果的排序方法 - -setAffectedStores:
设置可以在哪些数据存储中查询
[request setFetchBatchSize:500];//从数据库里每次加载500条数据来筛选数据
[request setFetchOffset:sizeCount];//读取数据库的游标偏移量,从游标开始读取数据
sizeCount = 10;
[request setFetchLimit:10];//每次要取多少条数据,10就是每次从数据库读取10条数据
NSPredicate用于查询和过滤
在SQL中作为查询条件通常用WHERE,但在COREDATA中作为查询条件就可以用到NSPredicate.
NSPredicate 不单可以和COREDATA中的FetchRequest 配合使用。也可以与NSArray配合使用
一个线程用一个NSManagedObjectContext对象.
使用coredata 在项目中建立表,它会自己来生成数据库,而在每个表中都有它自己生成的Z_PK,Z_ENT,Z_OPT 这三个字段,
Z_PK 表的主键,从1开始递增, 具有唯一性
可以通过主键访问和获取对象的途径:
NSFetchRequest request = [[NSFetchRequest alloc] init];
[request setEntity:entity];
[request setResultType:NSManagedObjectIDResultType];
[request setFetchBatchSize:20];
NSError error = nil;
NSArray items = [context executeFetchRequest:request error:&error];
for (NSManagedObjectID objectID in items) {
NSManagedObject* object = [context objectWithID:objectID];
...
}
Z_ENT 表在xcdatamodel 中的索引值,如果有6个表那么它的值的区间就是[1,6 ]
Z_OPT 表示的是每条数据被操作的次数,初始化值为1,只要是增删改查都会加1
3.其他记录
方便查阅
- 通过core data存储任意类型的数据:http://blog.csdn.net/likendsl/article/details/8549333
- 多表关联时, 动态设置删除关系.:http://blog.csdn.net/fengsh998/article/details/8090111
- 批量操作、聚合操作、WWDC 2015新特性: http://www.cocoachina.com/ios/20150730/12785.html
4.问题记录
当查询返回数据是fault时, 可以加上这句试试:
[request setReturnsObjectsAsFaults:NO];
学习记录, 如有错误, 敬请指出, 谢谢
Core Data 学习简单整理01的更多相关文章
- 关于Core Data的一些整理(五)
关于Core Data的一些整理(五) 在Core Data中使用NSFetchedResultsController(以下简称VC)实现与TableView的交互,在实际中,使用VC有很多优点,其中 ...
- 关于Core Data的一些整理(四)
关于Core Data的一些整理(四) 调用Core Data文件中的Request模板进行条件匹配 //获取ObjectModel相当于获取Core Date文件 NSManagedObjectMo ...
- 关于Core Data的一些整理(三)
关于Core Data的一些整理(三) 关于Core Data Stack的四种类与它们的关系如下: NSManagedObjectModel NSPersistentStore NSPersiste ...
- 关于Core Data的一些整理(二)
关于Core Data的一些整理(二) 创建NSManagedObject的子类时,有一点是在这中间要强调的一点是,要不要勾选 Use scalar properties for primitive ...
- 关于Core Data的一些整理(一)
关于Core Data的一些整理(一) 在Xcode7.2中只有Mast-Debug和Single View中可以勾选Use Core Data 如果勾选了Use Core Data,Xcode会自动 ...
- Core Data 的简单使用
认识cocoa Data在ios开发中的环境情况. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/f ...
- Core Data的简单用法
#import "ViewController.h" // 第一步:引入头文件AppDelegate #import "AppDelegate.h" #impo ...
- kafka学习笔记整理01
Apache Kafka 消息中间件->流式数据处理平台 特点: 高可靠性(分布式.分区.复制和容错).高吞吐量.持久化 消息模式:1)队列式(或点对点):在点对点消息系统中,消息被保存在队列中 ...
- 使用Core Data应避免的十个错误
原文:Avoiding Ten Big Mistakes iOS Developers Make with Core Data http://www.cocoachina.com/applenew ...
随机推荐
- C++学习笔记3——类的封装(1)
封装: 1.把属性和方法进行封装. 2.对属性和方法进行访问控制. class和struct的区别: class和struct的唯一区别是默认的访问权限不一样.struct的默认访问权限是public ...
- easyui combo+pagination 图标选择器
从数据库读取分页显示 $(function () { initTable(1, 180); $('#cc').combo({ editable: false, panelWidth: 'auto', ...
- iPhone 被同步到 Mac上后 如果不希望更新到Mac上在哪里删除?
前往文件夹 /Users/用户名/Library/Application Support/MobileSync 直接删除 就行了(同时要倾倒废纸篓). 目前iPhone链接Mac 后 不让 ...
- angular-fullstack test
1:运行yo 提示我可以升级到1.4.7版本,下面进行升级 提示需要npm>=2.8.0下面进行升级npm y@y:angular-fullstack-test$ npm install npm ...
- C51与汇编语言混合编程
函数内部混合编程 若想在C语言函数内部使用汇编语言,应使用以下Cx51编译器控制命令: #pragma asm ; Assembly code #pragma endasm 功能作用:asm和end ...
- 如何在一台机器上安装两个MYSQL数据库
1.正常安装第一个mysql(安装步骤省略) 2.在控制面板里停止第一个mysql服务 3.将C:\Program Files\MySQL目录下的所有目录和文件copy到另外一个路径,我这里是copy ...
- -_-#【Angular】工具函数
AngularJS学习笔记 上下文绑定 var f = angular.bind({a: 'xx'}, function() { console.log(this.a) }) f() // 'xx' ...
- Matlab:拟合(2)
非线性最小二乘拟合: 解法一:用命令lsqcurvefit function f = curvefun(x, tdata) f = x() + x()*exp() * tdata); %其中x() = ...
- HDU5032 -- Always Cook Mushroom 树状数组 14年北京网络赛
题意:1000*1000的格子, 坐标为(1, 1) ~ (1000, 1000), 常数 A, B, 点(x, y)权值为 (x + A) * (y + B), q次询问, 每次询问(0, 0) ...
- 四种方法解析JSON数据
(1)使用TouchJSon解析方法:(需导入包:#import "TouchJson/JSON/CJSONDeserializer.h") //使用TouchJson来解析北京的 ...