CoreData学习记录

来源:互联网 发布:下载动画的软件 编辑:程序博客网 时间:2024/05/22 00:29

分类: IOS 718人阅读 评论(8) 收藏 举报
objective-centitydescriptorschemasqlite

先来无事,学习了一下CoreData。我对CoreData的理解:CoreData是一个很强大的东西,如果按照层次来划分,他应该处于sqlite之上,应该说位于MVC的model层。有了它,我们可以很自然地和数据库打交道,避免了繁琐的sql语句.

下面这些图是复制别人的,最下面的代码是出自本人之手

Core Data的核心——托管对象

托管对象是要存储到数据库中的对象的一种表示,可以看成是SQL记录,它通常包含一些字段,这些字段与应用程序中要存储的对象的属性进行匹配,创建托管对象后,必须将气托管到托管对象上下文中,然后才可以存储到数据库中。

托管对象上下文:

托管对象上下文包含所有的托管对象,这些托管对象已经为提交给数据库准备就绪,在托管对象上下文中,可以添加、修改和删除托管对象,这一层相当于应用程序和数据库之间的缓冲区。

托管对象表:

托管对象表描述了数据库的架构(schema),供托管对象上下文与数据库交互时使用。托管对象表包含一些列实体描述,每个实体都描述了一个数据库表,用于将托管对象映射到数据库条目。


下面来创建一个Core Data

首先要保证引入了CoreData.framwork框架到项目中,然后新建模型文件,New File——Core Data中的Data Model,然后命名为CDJournal.Xcdatamodel,这里我们做一个简单的记录流水账的程序。

接下来是定义数据库实体,选中CDJournal.Xcdatamodel文件打开表编辑器,点击添加一个名为Entry的实体,然后可以为实体添加属性并指定属性的数据类型。还可以创建其他实体,如果一个实体包含另一个实体,可通过拖放建立关系,类似于SQL外键,比如建立一个Author实体可以有多个Entry。建立实体及属性如下图:



创建完实体后必须生成表示数据库对象的类,使我们能在代码中表示实体,选择Entry实体,然后选择菜单Editor——Create NSManagedObject Subclass,点击create,就完成了。完成后可以看到工程中多了一个Entry的h和m文件,这就是Core Data模型中的实体对象。基本准备工作就完成了,如下是工程目录:


model层多了 我们所创建的Entry,生成的model

下面我们来看看,怎么与数据库关联,以及怎么处理单表的增删改查

我用了一个单例:

h文件:

[objc] view plaincopyprint?
  1. #import <Foundation/Foundation.h>  
  2. #import <CoreData/CoreData.h>  
  3.   
  4. @interface HandleCoreData : NSObject  
  5. @property (nonatomic,strong,readonlyNSManagedObjectContext * objectContext;  
  6. @property (nonatomic,strong,readonlyNSManagedObjectModel * objectModel;  
  7. @property (nonatomic,strong,readonlyNSPersistentStoreCoordinator * presistentCoord;  
  8.   
  9. +(NSManagedObjectContext *)ShareObjectContext;  
  10. @end  

m文件

[objc] view plaincopyprint?
  1. #import "HandleCoreData.h"  
  2.   
  3. @implementation HandleCoreData  
  4. @synthesize objectContext;  
  5. @synthesize objectModel;  
  6. @synthesize presistentCoord;  
  7.   
  8.   
  9. +(NSManagedObjectContext *)ShareObjectContext  
  10. {  
  11.     static NSManagedObjectContext * mangedObjectContext = Nil;  
  12.     if (mangedObjectContext == nil)  
  13.     {  
  14.         mangedObjectContext = [[NSManagedObjectContext alloc] init];  
  15.         //参数为nil代表获取的为主束,获取建立的模型  
  16.         NSManagedObjectModel * mangedobjectModel = [NSManagedObjectModel mergedModelFromBundles:nil];  
  17.         //将建立的模型与数据库关联,以达到实现数据持久化的目的  
  18.         NSPersistentStoreCoordinator * coordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:mangedobjectModel];  
  19.         //初始化数据库的路径,注意数据库的名称需要和Xcdatemodel相同  
  20.         NSString * databaseParth = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"CDmodel.sqlite"];  
  21.         NSLog(@"datapath = %@",databaseParth);  
  22.         NSError * error = nil;  
  23.         [coordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:[NSURL fileURLWithPath:databaseParth] options:nil error:&error];  
  24.         [mangedObjectContext setPersistentStoreCoordinator:coordinator];  
  25.     }  
  26.     return mangedObjectContext;  
  27. }  
  28. @end  

下面是处理增删改查得源码:

AppDelegate中:

[objc] view plaincopyprint?
  1. - (void)applicationWillTerminate:(UIApplication *)application  
  2. {  
  3.     // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.  
  4.     NSError *error;  
  5.     NSManagedObjectContext *o_context = [HandleCoreData ShareObjectContext];  
  6.     if (o_context != nil) {  
  7.         //hasChanges方法是检查是否有未保存的上下文更改,如果有,则执行save方法保存上下文  
  8.         if (o_context && ![o_context save:&error]) {  
  9.             NSLog(@"Error: %@,%@",error,[error userInfo]);  
  10.             abort();  
  11.         }  
  12.     }  
  13. }  

下面是触发事件:

添加数据:

[objc] view plaincopyprint?
  1. P_info * info = [NSEntityDescription insertNewObjectForEntityForName:@"P_info" inManagedObjectContext:[HandleCoreData ShareObjectContext]];  
  2. [info setId:[NSNumber numberWithInt:1]];  
  3. [info setName:@"jjy"];  
  4. [info setBirthday:[NSNumber numberWithInt:1989]];  
  5. [info setAge:[NSNumber numberWithInt:24]];  
  6.   
  7. NSError * error = nil;  
  8. if ([[HandleCoreData ShareObjectContext] save:&error])  
  9. {  
  10.     NSLog(@"save success");  
  11. }  
  12. else  
  13. {  
  14.     NSLog(@"error = %@",error);  
  15. }  

修改数据,查询数据和删除数据

[objc] view plaincopyprint?
  1. //    //查询数据  
  2. //    //创建取回数据请求  
  3.     NSFetchRequest * getDataRequest = [[NSFetchRequest alloc] init];  
  4.     //设置要检索哪一个对象  
  5.     NSEntityDescription * entity = [NSEntityDescription entityForName:@"P_info" inManagedObjectContext:[HandleCoreData ShareObjectContext]];  
  6.     //设置请求实体  
  7.     [getDataRequest setEntity:entity];  
  8.     //指定对结果的排序方式  
  9.     NSSortDescriptor * descriptor = [[NSSortDescriptor alloc] initWithKey:@"id" ascending:YES];  
  10.     [getDataRequest setSortDescriptors:[NSArray arrayWithObjects:descriptor, nil nil]];  
  11.     NSError * error = nil;  
  12.     NSArray * resultArr = [[HandleCoreData ShareObjectContext] executeFetchRequest:getDataRequest error:&error];  
  13.     [resultArr enumerateObjectsUsingBlock:^(P_info * obj, NSUInteger idx, BOOLBOOL *stop) {  
  14.         NSLog(@"name = %@",obj.name);  
  15.     }];  
  16.       
  17.     //更新数据  
  18.     //和保存一样  
  19.       
  20.     //删除数据  
  21.     [resultArr enumerateObjectsUsingBlock:^(P_info * obj, NSUInteger idx, BOOLBOOL *stop) {  
  22.         NSLog(@"name = %@",obj.name);  
  23.         if ([obj.name isEqualToString:@"jjy"])  
  24.         {  
  25.             [[HandleCoreData ShareObjectContext] deleteObject:obj];  
  26.         }  
  27.     }];  
  28.     [[HandleCoreData ShareObjectContext] save:&error];  
  29.       
  30.    }  

                                                                                                               源码下载

0 0
原创粉丝点击