上一篇中我们已经使用CoreData创建了一个SQLite数据库

CoreData的简单使用(一)数据库的创建

现在对数据库进行数据的CRUD(增删改查)

1.Data Model 的设置

  创建一个DataModel,取名CRUD.xcdatamodeld,添加Entity(Library和Book),添加属性,在Book中设置和Library的关联关系(一个Book可以存放在一个Library里)

Book的属性和关联关系(选择Destination为Library,关系名称取名为library)注意区分大小写

Library的属性:

创建NSManagerObject subclass:

2. 在viewController.m来进行CRUD,注意方法的调用下面代码都抽离成方法,对数据进行操作都要创建_context对象(调用creatSQLite方法)

(1)导入头文件

   #import "Library.h"

    #import "Book.h"

    #import <CoreData/CoreData.h>

  (2)设置context属性,因为我们是利用context进行CRUD,所以把它设置成一个属性或者全局变量

@interface ViewController ()

@property (strong, nonatomic) NSManagedObjectContext *context;

@end

  (3)创建数据库

- (void)creatSQLite
{
//1.创建NSManagedObjectModel对象
NSURL *dataModelURL = [[NSBundle mainBundle] URLForResource:@"CRUD" withExtension:@"momd"];
NSManagedObjectModel *dataModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:dataModelURL]; //2.创建NSPersistentStoreCoordinator对象
NSPersistentStoreCoordinator *psc = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:dataModel];
//设置数据库保存路径
NSString *path = [NSHomeDirectory() stringByAppendingString:@"/Documents/CRUD.sqlite"];
NSLog(@"%@",path); //注意这里不能用[NSURL URLWithString:<#(nonnull NSString *)#>];
NSURL *pathURL = [NSURL fileURLWithPath:path];
//配置库的类型为SQLite
[psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:pathURL options:nil error:nil]; //3.创建_context并与psc进行关联
_context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
_context.persistentStoreCoordinator = psc;
}

去沙盒里找到数据库,查看一下,成功创建,关联关系也已经建立好了,Book里有一个LIBRARY的属性

   

3.添加数据

- (void)creatManagerObject
{
//NSManagerObject或它的子类都要用NSEntityDescription来描述
Library *libraryOne = [NSEntityDescription insertNewObjectForEntityForName:@"Library" inManagedObjectContext:_context];
libraryOne.libraryName = @"图书馆1";
Library *libraryTwo = [NSEntityDescription insertNewObjectForEntityForName:@"Library" inManagedObjectContext:_context];
libraryTwo.libraryName = @"图书馆2"; Book *bookOne = [NSEntityDescription insertNewObjectForEntityForName:@"Book" inManagedObjectContext:_context];
bookOne.bookName = @"时间简史";
bookOne.library = libraryOne;
Book *bookTwo = [NSEntityDescription insertNewObjectForEntityForName:@"Book" inManagedObjectContext:_context];
bookTwo.bookName = @"全球通史";
bookTwo.library = libraryTwo;
Book *bookThree = [NSEntityDescription insertNewObjectForEntityForName:@"Book" inManagedObjectContext:_context];
bookThree.bookName = @"鲁滨逊漂流记";
bookThree.library = libraryTwo; //利用_context同步数据至数据库
if ([_context save:nil])
{
NSLog(@"添加数据成功");
}; }

数据已经成功添加了  注意:ZBOOK中的ZLIBRARY对应的是ZLIBRARY的Z_PK,不要和代码中的1,2混淆,

4.查询数据

- (void)retrieveManagerObject
{
//查询数据需要用到NSFetchRequest
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Book"];
//用谓词进行查询找出书名中最后一个是史字的图书
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"bookName like '*史'"];
//fetchRequest与谓词关联
fetchRequest.predicate = predicate;
//查询
NSArray *resultArr = [_context executeFetchRequest:fetchRequest error:nil]; //对查询到的结果进行遍历,打印书名
if (resultArr)
{
for (Book *book in resultArr)
{
NSLog(@"bookName = %@",book.bookName);
}
} }

查询结果如下       注意:这里容易造成错误的就是谓词的使用,如果没有对应得属性就会造成崩溃;

5.修改数据

- (void)updateManagerObject
{
//更新数据前需要先查询到数据
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Book"];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"bookName = '鲁滨逊漂流记'"];
fetchRequest.predicate = predicate;
NSArray *resultArr = [_context executeFetchRequest:fetchRequest error:nil]; if (!resultArr)
{
return;
}
//把查询到的书名全都替换成“生物医学工程”
Book *book = [resultArr firstObject];
book.bookName = @"生物医学工程";
//同步数据到数据库
if([_context save:nil])
{
NSLog(@"数据修改成功");
}
else
{
NSLog(@"数据修改失败");
} }

结果,已经把“鲁滨逊漂流记”的书名修改成了“生物医学工程”

6.删除数据

- (void)deleteManagerObject
{
//删除数据前先要查询到需要删除的数据
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Book"];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"bookName = '生物医学工程'"];
fetchRequest.predicate = predicate;
NSArray *resultArr = [_context executeFetchRequest:fetchRequest error:nil]; if (!resultArr)
{
return;
} Book *book = [resultArr firstObject];
//删除数据
[_context deleteObject:book];
//同步至数据库
if([_context save:nil])
{
NSLog(@"删除数据成功");
}
else
{
NSLog(@"删除数据失败");
} }

结果,“生物医学工程”这本书已经被成功删除

7.版本迁移

模型文件的版本迁移:

1.原则:不能删除原来的模型文件,而是新增模文件的版本。

2.步骤:

(1)创建模型文件的新版本:Editor/Add Model Version

(2)设置Current Model Version为新版本。

(3)在配置NSPersistentStoreCoordinator时,添加设置字典,里面有相关键值对配置设置选项。

3.实现

(1)选中工程中的 xcdaramodeId 文件,Menu->Editor->Add Model Version

(2)  添加完成后,xcdaramodeId 文件可以展开,可以看到新增加的Model文件 ,在右侧工具栏选择Current Model Version 为新的Model文件

(3)在CRUD 2Z中添加新的实体和属性

(4)在ViewController.m   - (void)creatSQLite方法中修代码,主要是NSPersistentStoreCoordinator的配置字典

     之前 addPersistentStoreWithType: configuration:  URL: options: error: 方法中options传的都是nil

     修改后传入配置字典

NSDictionary *optionsDic = @{
//自动版本迁移
NSMigratePersistentStoresAutomaticallyOption : @YES,
//自动映射
NSInferMappingModelAutomaticallyOption : @YES }; [psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:pathURL options:optionsDic error:nil];

(5)运行,找到数据库进行查看Person已经被添加进来了,数据也都正确

   

上述代码只能是对数据模型增加实体或者可选属性时,才可以这样迁移(轻量级迁移 Lightweight Migration

CoreData的简单使用(二)数据的增删改查,轻量级的版本迁移的更多相关文章

  1. CoreData 从入门到精通(二) 数据的增删改查

    在上篇博客中,讲了数据模型和 CoreData 栈的创建,那下一步就是对数据的操作了.和数据库一样,CoreData 里的操作也无非是增删改查.下面我们将逐步讲解在 CoreData 中进行增删改查的 ...

  2. SQLAlchemy(二):SQLAlchemy对数据的增删改查操作、属性常用数据类型详解

    SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 目录 SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 1.用se ...

  3. Mybatis学习总结(二)—使用接口实现数据的增删改查

    在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...

  4. Hibernate3回顾-5-简单介绍Hibernate session对数据的增删改查

    5. Hibernate对数据的增删改查 5.1Hibernate加载数据 两种:get().load() 一. Session.get(Class arg0, Serializable arg1)方 ...

  5. Django框架之第二篇--app注册、静态文件配置、form表单提交、pycharm连接数据库、django使用mysql数据库、表字段的增删改查、表数据的增删改查

    本节知识点大致为:静态文件配置.form表单提交数据后端如何获取.request方法.pycharm连接数据库,django使用mysql数据库.表字段的增删改查.表数据的增删改查 一.创建app,创 ...

  6. 最简单的jsp+servlet的增删改查代码

    package ceet.ac.cn.dao; import java.sql.Connection; import java.sql.PreparedStatement; import java.s ...

  7. vue实现对表格数据的增删改查

    在管理员的一些后台页面里,个人中心里的数据列表里,都会有对这些数据进行增删改查的操作.比如在管理员后台的用户列表里,我们可以录入新用户的信息,也可以对既有的用户信息进行修改.在vue中,我们更应该专注 ...

  8. Node.js + MySQL 实现数据的增删改查

    通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-cru ...

  9. SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询

    SQL Server知识点回忆篇(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询 1. insert 如果sql server设置的排序规则不是简体中文,必须在简体中文字符串前加N, ...

  10. mysql学习笔记一 —— 数据的增删改查

    1.连接mysql mysql 直接回车(是以root身份,密码空,登陆的是本机localhost) [root@www mysql]# mysql -uroot -p123 -S /var/lib/ ...

随机推荐

  1. 轻松学习Ionic (二) 为Android项目集成Crosswalk(更新官方命令行工具)

        现在集成crosswalk不用这么麻烦了!官方的命令行工具已经能让我们一步到位,省去很多工作,只需在cmd中进入项目所在目录(不能有中文目录,还得FQ),执行: ionic browser a ...

  2. 盒模型Box Model(浮动)

    一.标准盒模型的大小:border+padding+content(width)        怪异盒模型大小:padding+border   二.display inline  默认,且变为行由内 ...

  3. 大数据架构:flume-ng+Kafka+Storm+HDFS 实时系统组合

    http://www.aboutyun.com/thread-6855-1-1.html 个人观点:大数据我们都知道hadoop,但并不都是hadoop.我们该如何构建大数据库项目.对于离线处理,ha ...

  4. java.util.Scanner应用详解++扫描控制台输入

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  5. 编写delegate(明天补充)

    delegate基本上是一种callback机制,让别的类在

  6. hanoi双塔

    汉诺塔,经典的递归. 经典的汉诺塔游戏相信很多同学都会玩的,规则就不用赘述,百科一下就OK.有三个柱子A,B,C,A柱子上套有n个大小不等的盘子,任意两个盘子,上面的盘子一定小于下面的盘子.现在请你编 ...

  7. C++ const修饰函数、函数参数、函数返回值

    const修饰函数 在类中将成员函数修饰为const表明在该函数体内,不能修改对象的数据成员而且不能调用非const函数.为什么不能调用非const函数?因为非const函数可能修改数据成员,cons ...

  8. validate中remote的用法

    jquery中的插件validate主要可以用于表单验证,极大地方便了我们,而validate中的remote方法更是非常的方便.以下介绍它的两个主要用途 1.注册时用于验证用户名是否存在 >& ...

  9. Memcache存储大数据的问题

    Memcached存储单个item最大数据是在1MB内,假设数据超过1M,存取set和get是都是返回false,并且引起性能的问题. 我们之前对排行榜的数据进行缓存,因为排行榜在我们全部sql se ...

  10. css中>,+,~的用法

    1.>的用法 A>B选择A的所有子元素B(只选择一代) 2.+的用法 A+B选择紧随着A的兄弟元素B 3.~的用法 A~B选择位置处于A后面的所有兄弟元素B(不包含兄弟元素的子元素)