iOS CoreData(数据库)

简介: 1. 创建项目2. 创建CoreDataManager来管理MTCoreDataManager.h文件#import #import @interface MTCoreDataManager : NSObject// 创建一个管理对象上下...

1. 创建项目

2. 创建CoreDataManager来管理

MTCoreDataManager.h文件

#import <Foundation/Foundation.h>
#import <CoreData/CoreData.h>
@interface MTCoreDataManager : NSObject

// 创建一个管理对象上下文
@property (nonatomic, strong) NSManagedObjectContext *managerContext;

// 单例
+ (instancetype)sharedManager;
@end

MTCoreDataManager.m文件


#import "MTCoreDataManager.h"

@implementation MTCoreDataManager
static MTCoreDataManager *sharedManager;
// 单例
+ (instancetype)sharedManager {
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        sharedManager = [MTCoreDataManager new];
    });
    return sharedManager;
}

// 创建一个管理对象上下文
- (NSManagedObjectContext *)managerContext {
    if (_managerContext == nil) {
        // 创建对象
        _managerContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
        
        // 给上下文设置持久化存储协调器
        // 模型文件url
        NSURL *url = [[NSBundle mainBundle] URLForResource:@"Person" withExtension:@"momd"];
        // 根据url获取到模型文件
        NSManagedObjectModel *model = [[NSManagedObjectModel alloc] initWithContentsOfURL:url];
        // 设置模型文件
        NSPersistentStoreCoordinator *persitent = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];
        
        // 数据路径放置在沙盒
        NSArray *documentArr =  NSSearchPathForDirectoriesInDomains(NSDocumentationDirectory, NSUserDomainMask, YES);
        NSString *documentPath = [[documentArr firstObject] stringByAppendingPathComponent:@"person.db"];
        NSLog(@"%@", documentPath);
        // 获取文件路径的url
        NSURL *pathUrl = [NSURL fileURLWithPath:documentPath];
        // 添加数据库文件路径
        [persitent addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:pathUrl options:nil error:nil];
        // 设置持久化存储协调器
        [_managerContext setPersistentStoreCoordinator:persitent];
    }
    return _managerContext;
}

@end

3. 创建CoreData

右键项目->New File...->Core Data->Data Model->修改类名->点击create.


img_b7234174739f0e1d87e7126d2714b60f.png
图1.png

4. 创建实体类

点击上一步新建的Person.xcdatamodeld文件,选择左下角的Add Entity,接下来自己可修改实体名,并在右侧添加属性。


img_3d2557f33fdbb1cf71fdb91d0895e977.png
图2.png

5. 创建NSManagedObjectModel实体类

右键项目->Core Data->NSManagedObjectObject subclass->选择Person->next->next->create。创建好之后项目结构如下:


img_d32a86802c0feaf34c25bbe32bc17108.png
图2.png

6. 插入数据

// 插入
- (IBAction)insert {
    // 通过实体描述出实体对象
    Person *person = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:[MTCoreDataManager sharedManager].managerContext];
    person.name = @"mazaiting";
    person.age = @(24);
    // 提交数据
    [[MTCoreDataManager sharedManager].managerContext save:nil];
    NSLog(@"插入成功");
}

7. 查询数据

// 查询
- (IBAction)fetch {
    // 查询请求
    NSFetchRequest *request = [[NSFetchRequest alloc] init];
    
    // 设置参数
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Person" inManagedObjectContext:[MTCoreDataManager sharedManager].managerContext];
    // 设置实体
    request.entity = entity;
    // 谓词--类似于sql中的where
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age = %d", 24];
    // 设置谓词
    request.predicate = predicate;
    // 排序
    NSSortDescriptor *sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:YES];
    // 设置排序
    request.sortDescriptors = @[sort];
    // 执行查询请求
    NSArray *arr = [[MTCoreDataManager sharedManager].managerContext executeFetchRequest:request error:nil];
    if (arr.count == 0) {
        NSLog(@"表中无数据");
    }
    // 打印结果
    for (Person *person in arr) {
        NSLog(@"name: %@, age: %@", person.name, person.age);
    }
}

8. 更新数据

// 更新
- (IBAction)update {
    // 创建请求
    NSFetchRequest *request = [[NSFetchRequest alloc] init];
    // 设置参数
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Person" inManagedObjectContext:[MTCoreDataManager sharedManager].managerContext];
    // 设置实体
    request.entity = entity;
    // 设置谓词
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age = %d", 24];
    request.predicate = predicate;
    // 执行请求
    NSArray *arr = [[MTCoreDataManager sharedManager].managerContext executeFetchRequest:request error:nil];
    
    for (Person *person in arr) {
        person.name = @"zaiting";
    }
    
    [[MTCoreDataManager sharedManager].managerContext save:nil];
    NSLog(@"更新成功");
}

9. 删除数据

// 删除
- (IBAction)delete {
    // 创建请求
    NSFetchRequest *request = [[NSFetchRequest alloc] init];
    // 获取实体
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Person" inManagedObjectContext:[MTCoreDataManager sharedManager].managerContext];
    // 设置实体
    request.entity = entity;
    // 创建谓词
    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"age = %d", 24];
    // 设置谓词
    request.predicate = predicate;
    // 执行命令
    NSArray *arr = [[MTCoreDataManager sharedManager].managerContext executeFetchRequest:request error:nil];
    for (Person *person in arr) {
        [[MTCoreDataManager sharedManager].managerContext deleteObject:person];
    }
    NSLog(@"删除成功");
}

10. 整个流程打印

img_d135bdbbd669e77daffa927469061c61.png
图3.png
目录
相关文章
|
8月前
|
存储 数据库 iOS开发
IOS开发数据存储:什么是 CoreData?如何在应用中使用它?
IOS开发数据存储:什么是 CoreData?如何在应用中使用它?
239 0
|
Swift iOS开发
iOS CoreData 创建 NSManageObject 以及创建 NSManageObject 文件类型切换
iOS CoreData 创建 NSManageObject 以及创建 NSManageObject 文件类型切换
91 0
|
SQL 存储 数据库
iOS Sqlite数据库的使用
iOS Sqlite数据库的使用
185 0
iOS Sqlite数据库的使用
|
数据管理 iOS开发 开发者
iOS中CoreData数据管理系列四——进行数据与页面的绑定
iOS中CoreData数据管理系列四——进行数据与页面的绑定
164 0
iOS中CoreData数据管理系列四——进行数据与页面的绑定
|
存储 XML 数据管理
iOS中CoreData数据管理系列三——添加与查询数据
iOS中CoreData数据管理系列三——添加与查询数据
286 0
iOS中CoreData数据管理系列三——添加与查询数据
|
SQL 数据管理 数据库
iOS中CoreData数据管理系列一——初识CoreData
iOS中CoreData数据管理系列一——初识CoreData
171 0
iOS中CoreData数据管理系列一——初识CoreData
|
设计模式 数据库 iOS开发
使用iOS原生sqlite3框架对sqlite数据库进行操作(二)
使用iOS原生sqlite3框架对sqlite数据库进行操作
229 0
使用iOS原生sqlite3框架对sqlite数据库进行操作(二)
|
SQL 开发框架 移动开发
使用iOS原生sqlite3框架对sqlite数据库进行操作(一)
使用iOS原生sqlite3框架对sqlite数据库进行操作
514 0
使用iOS原生sqlite3框架对sqlite数据库进行操作(一)
|
存储 缓存 数据管理
iOS中CoreData数据管理系列二——CoreData框架中三个重要的类
iOS中CoreData数据管理系列二——CoreData框架中三个重要的类
253 0
|
开发框架 关系型数据库 MySQL
使用iOS原生sqlite3框架对sqlite数据库进行操作(五)
使用iOS原生sqlite3框架对sqlite数据库进行操作
198 0