博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS CoreData (一) 增删改查
阅读量:6278 次
发布时间:2019-06-22

本文共 7140 字,大约阅读时间需要 23 分钟。

Core Data是iOS5之后才出现的一个框架,提供了直接使用SQLite数据库的大部分灵活性,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象,通过CoreData管理应用程序的数据模型,可以极大程度减少需要编写的代码数量!

示例Demo:

1、首先创建一个coreData 模型文件:系统创建或者自己创建

2、在data Model 中创建项目中需要用到的实体(Entities),例如,创建一个Student 实体(第一字母必须是大写),以及添加一些name、age、sex 等属性,如下图

3、生成对应实体的实体类,在此之前要注意下图两个设置部分,否则会引起崩溃现象

4、生成上下文 关联数据库

  • NSManagedObjectContext 管理对象,上下文,持久性存储模型对象,处理数据与应用的交互
  • NSManagedObjectModel 被管理的数据模型,数据结构
  • NSPersistentStoreCoordinator 添加数据库,设置数据存储的名字,位置,存储方式
  • NSManagedObject 被管理的数据记录
  • NSFetchRequest 数据请求
  • NSEntityDescription 表格实体结构
①、自己创建模型文件时需要以下代码来手动生成上下文,关联数据库
//创建数据库- (void)createSqlite{        //1、创建模型对象    //获取模型路径    NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"Model" withExtension:@"momd"];    //根据模型文件创建模型对象    NSManagedObjectModel *model = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];        //2、创建持久化存储助理:数据库    //利用模型对象创建助理对象    NSPersistentStoreCoordinator *store = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];        //数据库的名称和路径    NSString *docStr = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];    NSString *sqlPath = [docStr stringByAppendingPathComponent:@"coreData.sqlite"];    NSLog(@"数据库 path = %@", sqlPath);    NSURL *sqlUrl = [NSURL fileURLWithPath:sqlPath];        NSError *error = nil;    //设置数据库相关信息 添加一个持久化存储库并设置类型和路径,NSSQLiteStoreType:SQLite作为存储库    [store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:sqlUrl options:nil error:&error];        if (error) {        NSLog(@"添加数据库失败:%@",error);    } else {        NSLog(@"添加数据库成功");    }        //3、创建上下文 保存信息 对数据库进行操作    NSManagedObjectContext *context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];       //关联持久化助理    context.persistentStoreCoordinator = store;    _context = context;}复制代码
②、系统创建模型文件时会自动生成关联数据库的代码,在iOS10以下和iOS10之后生成的不一样,出现了一个新类NSPersistentContainer。

NSPersistentContainer是一个容器,封装了应用程序中的CoreData Stack(核心数据栈堆),简化了创建和管理的核心堆栈的数据处理创建NSManagedObjectModel,NSPersistentStoreCoordinator,NSManagedObjectContext。详情可以看看这篇文章:

AppDelegate * appDelegate = (AppDelegate *)[UIApplication sharedApplication].delegate;        NSPersistentContainer * container = appDelegate.persistentContainer;        //返回沙盒中存储数据库的文件夹URL路径,这是一个静态方法,表示数据库的文件路径是唯一的    NSURL * url = [NSPersistentContainer defaultDirectoryURL];        NSManagedObjectContext *viewContext = container.viewContext;        NSManagedObjectModel *managedObjectModel = container.managedObjectModel;        NSPersistentStoreCoordinator *persistentStoreCoordinator = container.persistentStoreCoordinator;    //使用存储调度器快速在多线程中操作数据库,效率非常高(比主线程操作块50倍!!!)    - (void)performBackgroundTask:(void (^)(NSManagedObjectContext *))block;复制代码

5.增删改查排

  • 写入数据
// 1.根据Entity名称和NSManagedObjectContext获取一个新的继承于NSManagedObject的子类Student    Student * student = [NSEntityDescription  insertNewObjectForEntityForName:@"Student"  inManagedObjectContext:_context];        //2.根据表Student中的键值,给NSManagedObject对象赋值    student.name = [NSString stringWithFormat:@"Mr-%d",arc4random()%100];    student.age = arc4random()%20;    student.sex = arc4random()%2 == 0 ?  @"美女" : @"帅哥" ;    student.height = arc4random()%180;    student.number = arc4random()%100    //   3.保存插入的数据    NSError *error = nil;    if ([_context save:&error]) {        [self alertViewWithMessage:@"数据插入到数据库成功"];    }else{        [self alertViewWithMessage:[NSString stringWithFormat:@"数据插入到数据库失败, %@",error]];    }复制代码
  • 删除数据
- (void)deleteData{       //创建删除请求    NSFetchRequest *deleRequest = [NSFetchRequest fetchRequestWithEntityName:@"Student"];        //删除条件    NSPredicate *pre = [NSPredicate predicateWithFormat:@"age < %d", 10];    deleRequest.predicate = pre;       //返回需要删除的对象数组    NSArray *deleArray = [_context executeFetchRequest:deleRequest error:nil];        //从数据库中删除    for (Student *stu in deleArray) {        [_context deleteObject:stu];    }       NSError *error = nil;    //保存--记住保存    if ([_context save:&error]) {        [self alertViewWithMessage:@"删除 age < 10 的数据"];    }else{        NSLog(@"删除数据失败, %@", error);    }}复制代码
  • 更新修改
//更新,修改- (void)updateData{        //创建查询请求    NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Student"];    NSPredicate *pre = [NSPredicate predicateWithFormat:@"sex = %@", @"帅哥"];    request.predicate = pre;        //发送请求    NSArray *resArray = [_context executeFetchRequest:request error:nil];        //修改    for (Student *stu in resArray) {        stu.name = @"且行且珍惜_iOS";    }      //保存    NSError *error = nil;    if ([_context save:&error]) {        [self alertViewWithMessage:@"更新所有帅哥的的名字为“且行且珍惜_iOS”"];    }else{        NSLog(@"更新数据失败, %@", error);    }  }复制代码
  • 读取查询
//读取查询- (void)readData{        /* 谓词的条件指令     1.比较运算符 > 、< 、== 、>= 、<= 、!=     例:@"number >= 99"          2.范围运算符:IN 、BETWEEN     例:@"number BETWEEN {1,5}"     @"address IN {'shanghai','nanjing'}"          3.字符串本身:SELF     例:@"SELF == 'APPLE'"          4.字符串相关:BEGINSWITH、ENDSWITH、CONTAINS     例:  @"name CONTAIN[cd] 'ang'"  //包含某个字符串     @"name BEGINSWITH[c] 'sh'"    //以某个字符串开头     @"name ENDSWITH[d] 'ang'"    //以某个字符串结束          5.通配符:LIKE     例:@"name LIKE[cd] '*er*'"   //*代表通配符,Like也接受[cd].     @"name LIKE[cd] '???er*'"          *注*: 星号 "*" : 代表0个或多个字符     问号 "?" : 代表一个字符          6.正则表达式:MATCHES     例:NSString *regex = @"^A.+e$"; //以A开头,e结尾     @"name MATCHES %@",regex          注:[c]*不区分大小写 , [d]不区分发音符号即没有重音符号, [cd]既不区分大小写,也不区分发音符号。          7. 合计操作     ANY,SOME:指定下列表达式中的任意元素。比如,ANY children.age < 18。     ALL:指定下列表达式中的所有元素。比如,ALL children.age < 18。     NONE:指定下列表达式中没有的元素。比如,NONE children.age < 18。它在逻辑上等于NOT (ANY ...)。     IN:等于SQL的IN操作,左边的表达必须出现在右边指定的集合中。比如,name IN { 'Ben', 'Melissa', 'Nick' }。          提示:     1. 谓词中的匹配指令关键字通常使用大写字母     2. 谓词中可以使用格式字符串     3. 如果通过对象的key     path指定匹配条件,需要使用%K          */        //创建查询请求    NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Student"];    //查询条件    NSPredicate *pre = [NSPredicate predicateWithFormat:@"sex = %@", @"美女"];    request.predicate = pre;     // 从第几页开始显示    // 通过这个属性实现分页    //request.fetchOffset = 0;    // 每页显示多少条数据    //request.fetchLimit = 6;    //发送查询请求    NSArray *resArray = [_context executeFetchRequest:request error:nil];        [self alertViewWithMessage:@"查询所有的美女"];  }复制代码
  • 排序
//排序- (void)sort{    //创建排序请求    NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Student"];    //实例化排序对象    NSSortDescriptor *ageSort = [NSSortDescriptor sortDescriptorWithKey:@"age"ascending:YES];    NSSortDescriptor *numberSort = [NSSortDescriptor sortDescriptorWithKey:@"number"ascending:YES];    request.sortDescriptors = @[ageSort,numberSort];    //发送请求    NSError *error = nil;    NSArray *resArray = [_context executeFetchRequest:request error:&error];    if (error == nil) {        [self alertViewWithMessage:@"按照age和number排序"];    }else{        NSLog(@"排序失败, %@", error);    }}复制代码
CoreData调试:

打开Product,选择Edit Scheme. 选择Arguments,在下面的ArgumentsPassed On Launch中添加下面两个选项,如图: (1)-com.apple.CoreData.SQLDebug (2)1

示例Github:

如果需要跟我交流的话: ※ Github:  ※ 个人博客: ※ 简书: ※ 微信公众号:iOS2679114653 ※ QQ:1685527540

转载地址:http://mcfva.baihongyu.com/

你可能感兴趣的文章
Javascript 中的 Array 操作
查看>>
java中包容易出现的错误及权限问题
查看>>
AngularJS之初级Route【一】(六)
查看>>
服务器硬件问题整理的一点总结
查看>>
SAP S/4HANA Cloud: Revolutionizing the Next Generation of Cloud ERP
查看>>
Mellanox公司计划利用系统芯片提升存储产品速度
查看>>
白帽子守护网络安全,高薪酬成大学生就业首选!
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>
智能照明造福千家万户 家居智能不再是梦
查看>>
物联网如何跳出“看起来很美”?
查看>>
浅谈MySQL 数据库性能优化
查看>>
《UNIX/Linux 系统管理技术手册(第四版)》——1.10 其他的权威文档
查看>>
灵动空间 创享生活
查看>>
《UNIX网络编程 卷1:套接字联网API(第3版)》——8.6 UDP回射客户程序:dg_cli函数...
查看>>
不要将时间浪费到编写完美代码上
查看>>
《第一桶金怎么赚——淘宝开店创业致富一册通》一一第1章 创业梦想,怎样起步...
查看>>
基于容器服务的持续集成与云端交付(三)- 从零搭建持续交付系统
查看>>