iOS--CoreData

简介

  Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象。在此数据操作期间,我们不需要编写任何SQL语句,这个有点类似于著名的Hibernate持久化框架,不过功能肯定是没有Hibernate强大的。简单地用下图描述下它的作用:

abc

左边是关系模型,即数据库,数据库里面有张person表,person表里面有id、name、age三个字段,而且有2条记录;

右边是对象模型,可以看到,有2个OC对象;

利用Core Data框架,我们就可以轻松地将数据库里面的2条记录转换成2个OC对象,也可以轻松地将2个OC对象保存到数据库中,变成2条表记录,而且不用写一条SQL语句。


模型文件

  在 Core Data ,需要进行映射的对象称为 实体 (entity) ,而且需要使用 Core Data 的模型文件来描述app中的所有实体和实体属性。这里以Person(人)和Card(身份证)2个实体为例子,先看看实体属性和实体之间的关联关系:
abc
Person实体中有:name(姓名)、age(年龄)、card(身份证)三个属性
Card实体中有:no(号码)、person(人)两个属性

接下来看看创建模型文件的过程:
1.选择模板
abcabc

2.添加实体


3.添加Person的2个基本属性



4.添加Card的1个基本属性



5.建立Card和Person的关联关系

        

右图中的表示Card中有个Person类型的person属性,目的就是建立Card跟Person之间的一对一关联关系(建议补上这一项),在Person中加上Inverse属性后,你会发现Card中Inverse属性也自动补上了



了解NSManagedObject

1.通过 Core Data 从数据库取出的对象,默认情况下都是 NSManagedObject 对象
  

2. NSManagedObject 的工作模式有点类似于 NSDictionary 对象,通过键 - 值对来存取所有的实体属性

1> setValue:forKey:存储属性值(属性名为key)

2>  valueForKey: 获取属性值 ( 属性名为 key)


CoreData中的核心对象



注:黑色表示类名,红色表示类里面的一个属性
发步骤总结:
1.初始化NSManagedObjectModel对象,加载模型文件,读取app中的所有实体信息
2.初始化NSPersistentStoreCoordinator对象,添加持久化库(这里采取SQLite数据库)
3.初始化NSManagedObjectContext对象,拿到这个上下文对象操作实体,进行CRUD操


代码实现

添加CoreData.framework和导入主头文件<CoreData/CoreData.h>

条件查询:使用谓词。

NSPredicate用于查询和过滤

在SQL中作为查询条件通常用WHERE,但在COREDATA中作为查询条件就可以用到NSPredicate.

NSPredicate 不单可以和COREDATA中的FetchRequest 配合使用。也可以与NSArray配合使用。

 

NSPredicate 中支持的关键词和条件符:

1、>,<,>=,<=,= 比较运算符。

如:

     NSPredicate * qcondition= [NSPredicate predicateWithFormat:@"salary >= 10000"];

2、字符串操作(包含):BEGINSWITH、ENDSWITH、CONTAINS

如:

        @"employee.name BEGINSWITH[cd] '李'" //姓李的员工

     @"employee.name ENDSWITH[c] '梦'"   //以梦结束的员工

     @"employee.name CONTAINS[d] '宗'"   //包含有"宗"字的员工

注:[c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。

 

3、范围:IN   ,BWTEEN

如:

    @"salary BWTEEN {5000,10000}"

    @"em_dept IN '开发'"

 

4、自身:SELF,这个只针对字符数组起作用。

如:

     NSArray * test = =[NSArray arrayWithObjects: @"guangzhou", @"beijing", @"shanghai", nil];

     @"SELF='beijing'"

 

5、通配符:LIKE

     LIKE 使用?表示一个字符,*表示多个字符,也可以与c、d 连用。

如:

     @"car.name LIKE '?he?'" //四个字符中,中间为he

     @"car.name LIKE '*jp'"   //以jp结束

 

6、正则表达式:MATCHES

如:

NSString *regex = @"^E.+e$";//以E 开头,以e 结尾的字符。
NSPredicate *pre= [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
if([pre evaluateWithObject: @"Employee"]){
NSLog(@"matches YES");

}else{
NSLog(@"matches NO");

}

 

7、逻辑运算符:AND、OR、NOT
如:

      @"employee.name = 'john' AND employee.age = 28"

 

8、占位符:
NSPredicate *preTemplate = [NSPredicate predicateWithFormat:@"name==$NAME"];
NSDictionary *dic=[NSDictionary dictionaryWithObjectsAndKeys:
@"Name1", @"NAME",nil];
NSPredicate *pre=[preTemplate predicateWithSubstitutionVariables: dic];
占位符就是字典对象里的key,因此你可以有多个占位符,只要key 不一样就可以了。


例如:

//查询请求

    NSFetchRequest *request=[[NSFetchRequest alloc] initWithEntityName:@"User"];

    

    //排序

    NSSortDescriptor *des=[NSSortDescriptor sortDescriptorWithKey:@"score" ascending:YES];

    [request setSortDescriptors:@[des]];

-------------使用谓词限定条件------------------    

    // 设置条件过滤(搜索name中包含字符串"Itcast-1"的记录,注意:设置条件过滤时,数据库SQL语句中的%要用*来代替,所以%Itcast-1%应该写成*Itcast-1*)

    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name like %@", @"*Itcast-1*"];

    request.predicate = predicate;

--------------------------------------------    

    //执行查询

    NSArray *array=[_context executeFetchRequest:request error:nil];





代码:
#import "AZViewController.h"
#import "User.h"
#import "INFO.h"
@interface AZViewController ()
{
    //CoreData 上下文对象指针
    NSManagedObjectContext *_context;
}
@end

@implementation AZViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    
    [self initCoreData];
    
}

#pragma mark -- 初始化CoreDate
-(void)initCoreData
{
    //01 将托管对象--(即是数据模型)托管给协调者
    
    //拿到托管对象--user
    
    NSManagedObjectModel *userModel=[NSManagedObjectModel mergedModelFromBundles:nil];//如果参数为nil,会将所有的托管对象都获取到。在这里我们只有一个User。所以就只拿出User这一个托管对象。
    
    //创建协调者
    NSPersistentStoreCoordinator *coordinator=[[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:userModel];
    
    //数据库路径
    NSString *path=[NSString stringWithFormat:@"%@/Documents/data2.db",NSHomeDirectory()];
    
    //关联数据库
    [coordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:[NSURL fileURLWithPath:path] options:nil error:nil];
    
    
    //02  创建上下文,关联协调者
    
    _context=[[NSManagedObjectContext alloc] init];
    _context.persistentStoreCoordinator=coordinator;
}

- (IBAction)addData:(id)sender
{
    //创建一个User对象
#if 1
    User *user=[NSEntityDescription insertNewObjectForEntityForName:@"User" inManagedObjectContext:_context];
    user.name=_name.text;
    user.score=[NSNumber numberWithInt:[_score.text intValue]];
    
    user.info=[NSEntityDescription insertNewObjectForEntityForName:@"INFO" inManagedObjectContext:_context];
    
    user.info.age=[NSNumber numberWithInt:21];
    user.info.sex=@"男";
    
    if ([_context save:nil]) {
        NSLog(@"保存成功");
    }else
    {
        NSLog(@"保存失败");
    }
#endif
    
    
    
#if 0  
    //注意CoreData中不能这样创建对象,必须按上面的方式创建对象。
    User *user=[[User alloc] init];
  
    user.name=@"zzz";
    user.score=[NSNumber numberWithInt:100];
    [_context insertObject:user];
    [_context save:nil];
#endif
}

- (IBAction)delData:(id)sender
{
    
    //查询请求
    NSFetchRequest *request=[[NSFetchRequest alloc] initWithEntityName:@"User"];
    
    //排序
    NSSortDescriptor *des=[NSSortDescriptor sortDescriptorWithKey:@"score" ascending:YES];
    [request setSortDescriptors:@[des]];
    
    //执行查询
    NSArray *array=[_context executeFetchRequest:request error:nil];
    for (User *user in array) {
        
        if ([user.name isEqualToString:_name.text])
        {
            [_context deleteObject:user];
            if ([_context save:nil])//原子性操作
            {
                NSLog(@"修改成功");
            }
        }
        
    }
    
}

- (IBAction)changeData:(id)sender
{
    //查询请求
    NSFetchRequest *request=[[NSFetchRequest alloc] initWithEntityName:@"User"];
    
    //排序
    NSSortDescriptor *des=[NSSortDescriptor sortDescriptorWithKey:@"score" ascending:YES];
    [request setSortDescriptors:@[des]];
    
    // 设置条件过滤(搜索name中包含字符串"Itcast-1"的记录,注意:设置条件过滤时,数据库SQL语句中的%要用*来代替,所以%Itcast-1%应该写成*Itcast-1*)
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name like %@", @"*Itcast-1*"];
    request.predicate = predicate;
    
    //执行查询
    NSArray *array=[_context executeFetchRequest:request error:nil];
    for (User *user in array) {
        
        if ([user.name isEqualToString:_name.text])
        {
            user.score=[NSNumber numberWithInt:[_score.text intValue]];
            if ([_context save:nil])//原子性操作
            {
                NSLog(@"修改成功");
            }
        }
        
    }

}

- (IBAction)selectData:(id)sender
{
   
    //查询请求
    NSFetchRequest *request=[[NSFetchRequest alloc] initWithEntityName:@"User"];
    
    //排序
    NSSortDescriptor *des=[NSSortDescriptor sortDescriptorWithKey:@"score" ascending:YES];
    [request setSortDescriptors:@[des]];
    
    //执行查询
    NSArray *array=[_context executeFetchRequest:request error:nil];
    showDataView.text=@"";
    for (User *user in array) {
        
        showDataView.text=[NSString stringWithFormat:@"%@name:%@  score:%d\n age:%d sex:%@",showDataView.text,user.name,[user.score intValue],[user.info.age intValue],user.info.sex];
    }
 
}
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    [_name resignFirstResponder];
    [_score resignFirstResponder];
}
@end



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值