iOS 数据库工具类分享

简介: iOS 数据库工具类分享 基于 对 FMDB 框架的封装,实现通过模型操作数据库的功能,不需要手写SQL语句,只要传入一个Model,框架会自动将Model内数据保存到指定数据库中, 并且会自动创建数据库,自动创建模型对应的表。

iOS 数据库工具类分享

基于 对 FMDB 框架的封装,实现通过模型操作数据库的功能,不需要手写SQL语句,只要传入一个Model,框架会自动将Model内数据保存到指定数据库中, 并且会自动创建数据库,自动创建模型对应的表。

项目地址

XWSqliteTool

功能列表

  1. 根据 Model 动态建表
  2. 若 Model 内字段发生变化自动进行表结构迁移
  3. 传入 Model 自动将 Model 内数据保存到数据库对应的表中
  4. 传入主键值获取 Model 模型数据
  5. 大数据保存,传入多个数据模型批量存储
  6. 多线程支持,多线程操作数据库需要使用 操作队列 进行操作。

使用说明

  1. 导入 XWSqliteTool
  2. 使需要操作的模型遵循 XWXModelProtocol 协议,并实现 +(NSString *)primaryKey 协议方法指定表的主键。

1. 动态建表

//根据模型建表
- (void)testCreateTableFromClass {
    [XWSqliteModelFMDBTool createTableFromClass:[XWPerson class] callBack:^(BOOL isSuccess) {
        XCTAssertTrue(isSuccess);
    }];
}

2. 模型字段改变自动进行表数据迁移

// 模型字段增加更新数据库
- (void)testUpdateModelTable {
    [XWSqliteModelFMDBTool updateTableFromCls:[XWPerson class] updateSqls:nil callBack:^(BOOL isSuccess) {
        XCTAssert(isSuccess == 1);
    }];
}

3. 自动保存一个Model到数据库 (自动创建数据库,自动建表)

// 插入/更新 单条数据模型
- (void)testInsertOneObj {
    [XWSqliteModelFMDBTool insertOrUpdateDataToSQLiteWithModel:[self demoPerson] isUpdateTable:YES callBack:^(BOOL isSuccess) {
        XCTAssertTrue(isSuccess);
    }];
}

4. 自动保存 Model 数组到数据库 (自动创建数据库,自动建表)

// 插入/更新 多条数据模型
- (void)testInsertObjs {
    [XWSqliteModelFMDBTool insertOrUpdateDataToSQLiteWithModels:[self demoPersons] isUpdateTable:YES callBack:^(BOOL isSuccess) {
        XCTAssertTrue(isSuccess);
    }];
}

5.传入主键值获取 Model 模型数据

// 查询 XWPerson 表中 主键 为 4 的模型
- (void)testQuery {
    [XWSqliteModelFMDBTool objectFromDatabaseWithPrimaryValue:4 modelCls:[XWPerson class] resultCallBack:^(XWPerson *obj) {
        NSLog(@"name:%@",obj.name);
    }];
}

6.多线程操作数据库

首先如果项目中需要多线程异步操作数据库,需要将对数据库操作集中管理,使用 dispatch_queue_t 进行统一管理。 例如Demo所示:

//
//  ViewController.m
//  XWSqliteToolDemo
//
//  Created by 邱学伟 on 2018/4/8.
//  Copyright © 2018年 邱学伟. All rights reserved.
//

#import "ViewController.h"
#import "XWSqliteModelFMDBTool.h"
#import "XWPerson.h"
@interface ViewController ()
@property (nonatomic, strong) dispatch_queue_t databaseQueue;
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    self.databaseQueue = dispatch_queue_create("com.company.app.database", 0);

    for (int i = 0; i < 1000; i++) {
        dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
            XWPerson *stu = [[XWPerson alloc] init];
            stu.name = [NSString stringWithFormat:@"极客学伟_%d",i];
            stu.sex = 1;
            stu.uid = [NSString stringWithFormat:@"%d",i];
            stu.height = 188;
            stu.address = @"北京回龙观";
            dispatch_sync(self.databaseQueue, ^{
                // do your database activity here
                [XWSqliteModelFMDBTool insertOrUpdateDataToSQLiteWithModel:stu isUpdateTable:YES callBack:^(BOOL isSuccess) {
                    NSLog(@"保存成功 %@, 线程 %@",stu.name,[NSThread currentThread]);
                }];
            });
        });
    }
}
@end
原文地址https://blog.csdn.net/qiuxuewei2012/article/details/80282784
相关文章
|
6月前
|
弹性计算 Linux 网络安全
数据库出现了网络连通性类相关问题的抓包方法
如下列举了数据库遇到连通性问题时,在三种不同的操作系统上抓包的方式。
94 2
|
7月前
|
存储 关系型数据库 数据库
Django创建应用、ORM的进阶使用及模型类数据库迁移1
Django创建应用、ORM的进阶使用及模型类数据库迁移1
74 0
|
7月前
|
存储 数据可视化 数据库
Django创建应用、ORM的进阶使用及模型类数据库迁移3
Django创建应用、ORM的进阶使用及模型类数据库迁移3
52 0
|
7月前
|
关系型数据库 MySQL 数据库
Django创建应用、ORM的进阶使用及模型类数据库迁移2
Django创建应用、ORM的进阶使用及模型类数据库迁移2
46 0
|
1月前
|
JavaScript Java 关系型数据库
基于vue的MOBA类游戏攻略分享平台23(程序+数据库+论文)可帮忙远程调试
基于vue的MOBA类游戏攻略分享平台23(程序+数据库+论文)可帮忙远程调试
|
4月前
|
SQL 数据库连接 数据库
VB.NET 中使用SqlConnection类连接到Microsoft SQL Server数据库的详细步骤
VB.NET 中使用SqlConnection类连接到Microsoft SQL Server数据库的详细步骤
90 0
|
10月前
|
SQL 数据库 数据库管理
Qt操作Sqlite类封装,及命令行导入csv文件到Sqlite数据库
Qt操作Sqlite类封装,及命令行导入csv文件到Sqlite数据库
|
8月前
|
XML Java 编译器
JdbcTemplate--spring 提供的一个操作数据库(表)功能强大的类
JdbcTemplate--spring 提供的一个操作数据库(表)功能强大的类
73 0
|
8月前
|
SQL Java 关系型数据库
JDBC(常用类与接口、实现数据库的增删查改)
1.Connection接口常用方法、2.DriverMange类、3.Statement接口,4.实现表的数据更新(增、改、删),5.实现数据查找(ResultSet接口),6.PreparedStatement 数据更新
99 0
JDBC(常用类与接口、实现数据库的增删查改)
|
9月前
ArcGIS:如何在地理数据库中创建关系类
ArcGIS:如何在地理数据库中创建关系类
169 0