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
目录
相关文章
|
9月前
|
存储 数据库 iOS开发
IOS开发数据存储:什么是 CoreData?如何在应用中使用它?
IOS开发数据存储:什么是 CoreData?如何在应用中使用它?
268 0
|
Swift iOS开发
iOS CoreData 创建 NSManageObject 以及创建 NSManageObject 文件类型切换
iOS CoreData 创建 NSManageObject 以及创建 NSManageObject 文件类型切换
102 0
|
SQL 存储 数据库
iOS Sqlite数据库的使用
iOS Sqlite数据库的使用
191 0
iOS Sqlite数据库的使用
|
数据管理 iOS开发 开发者
iOS中CoreData数据管理系列四——进行数据与页面的绑定
iOS中CoreData数据管理系列四——进行数据与页面的绑定
170 0
iOS中CoreData数据管理系列四——进行数据与页面的绑定
|
存储 XML 数据管理
iOS中CoreData数据管理系列三——添加与查询数据
iOS中CoreData数据管理系列三——添加与查询数据
290 0
iOS中CoreData数据管理系列三——添加与查询数据
|
SQL 数据管理 数据库
iOS中CoreData数据管理系列一——初识CoreData
iOS中CoreData数据管理系列一——初识CoreData
176 0
iOS中CoreData数据管理系列一——初识CoreData
|
设计模式 数据库 iOS开发
使用iOS原生sqlite3框架对sqlite数据库进行操作(二)
使用iOS原生sqlite3框架对sqlite数据库进行操作
236 0
使用iOS原生sqlite3框架对sqlite数据库进行操作(二)
|
SQL 开发框架 移动开发
使用iOS原生sqlite3框架对sqlite数据库进行操作(一)
使用iOS原生sqlite3框架对sqlite数据库进行操作
527 0
使用iOS原生sqlite3框架对sqlite数据库进行操作(一)
|
存储 缓存 数据管理
iOS中CoreData数据管理系列二——CoreData框架中三个重要的类
iOS中CoreData数据管理系列二——CoreData框架中三个重要的类
258 0
|
开发框架 关系型数据库 MySQL
使用iOS原生sqlite3框架对sqlite数据库进行操作(五)
使用iOS原生sqlite3框架对sqlite数据库进行操作
204 0

热门文章

最新文章

  • 1
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    24
  • 2
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    32
  • 3
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    27
  • 4
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    23
  • 5
    uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
    143
  • 6
    【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
    232
  • 7
    app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
    90
  • 8
    深入探索iOS开发中的SwiftUI框架
    143
  • 9
    ios样式开关按钮jQuery插件
    58
  • 10
    Android与iOS生态差异深度剖析:技术架构、开发体验与市场影响####
    75