https://github.com/Joker-King/JKDBModel

1.将FMDB和DBModel拖入项目中,然后添加libsqlite3.dylib

 
2.

#import "JKDBModel.h"
@interface WrksheetInfoModel : JKDBModel

3./** 数据库中是否存在表 */

+ (BOOL)isExistInTable;

/** 保存或更新 * 如果不存在主键,保存, * 有主键,则更新 */

- (BOOL)saveOrUpdate;

/** 保存单个数据 */

- (BOOL)save;

/** 批量保存数据 */

+ (BOOL)saveObjects:(NSArray *)array;

/** 更新单个数据 */

- (BOOL)update;

/** 批量更新数据*/

+ (BOOL)updateObjects:(NSArray *)array;

/** 删除单个数据 */

- (BOOL)deleteObject;

/** 批量删除数据 */

+ (BOOL)deleteObjects:(NSArray *)array;

/** 通过条件删除数据 */

+ (BOOL)deleteObjectsByCriteria:(NSString *)criteria;

/** 清空表 */

+ (BOOL)clearTable;/** 查询全部数据 */+ (NSArray *)findAll;

/** 通过主键查询 */

+ (instancetype)findByPK:(int)inPk;

/** 查找某条数据 */

+ (instancetype)findFirstByCriteria:(NSString *)criteria;

/** 通过条件查找数据 * 这样可以进行分页查询 @" WHERE pk > 5 limit 10" */

+ (NSArray *)findByCriteria:(NSString *)criteria;

/** * 创建表 * 如果已经创建,返回YES */

+ (BOOL)createTable;#pragma mark - must be override method

/** 如果子类中有一些property不需要创建数据库字段,那么这个方法必须在子类中重写 */

+ (NSArray *)transients;

4.使用示例

#pragma mark - 插入数据
/** 创建多条子线程 */
- (IBAction)insertData:(id)sender {
    for (int i = 0; i < 1; i++) {
        User *user = [[User alloc] init];
        user.name = [NSString stringWithFormat:@"麻子%d",i];
        user.sex = @"男";
        user.age = 10+i;
        dispatch_async(dispatch_get_global_queue(0, 0), ^{
            [user save];
        });
    }
}

/** 子线程一:插入多条用户数据 */
- (IBAction)insertData2:(id)sender {

    dispatch_queue_t q1 = dispatch_queue_create("queue1", NULL);
    dispatch_async(q1, ^{
        for (int i = 0; i < 5; ++i) {
            User *user = [[User alloc] init];
            user.name = @"赵五";
            user.sex = @"女";
            user.age = i+5;
            [user save];
        }
    });
}

- (IBAction)insertData3:(id)sender {
    for (int i = 0; i < 1000; ++i) {
        User *user = [[User alloc] init];
        user.name = @"张三";
        user.sex = @"男";
        user.age = i+5;
        [user save];
    }
}

/** 子线程三:事务插入数据 */
- (IBAction)insertData4:(id)sender {
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSMutableArray *array = [NSMutableArray array];
        for (int i = 0; i < 500; i++) {
            User *user = [[User alloc] init];
            user.name = [NSString stringWithFormat:@"李四%d",i];
            user.age = 10+i;
            user.sex = @"女";
            [array addObject:user];
        }
        [User saveObjects:array];
    });
}

#pragma mark - 删除数据
/** 通过条件删除数据 */
- (IBAction)deleteData:(id)sender {
//    [User deleteObjectsByCriteria:@" WHERE pk < 10"];
    [User deleteObjectsWithFormat:@"Where %@ < %d",@"pk",10];
}

/** 创建多个线程删除数据 */
- (IBAction)deleteData2:(id)sender {
    for (int i = 0; i < 5; i++) {
        User *user = [[User alloc] init];
        user.pk = 1+i;
        dispatch_async(dispatch_get_global_queue(0, 0), ^{
            [user deleteObject];
        });
    }
}

/** 子线程用事务删除数据 */
- (IBAction)deleteData3:(id)sender {

    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSMutableArray *array = [NSMutableArray array];
        for (int i = 0; i < 500; i++) {
            User *user = [[User alloc] init];
            user.pk = 501+i;
            [array addObject:user];
        }
        [User deleteObjects:array];
    });
}

#pragma mark - 修改数据
/** 创建多个线程更新数据 */
- (IBAction)updateData1:(id)sender {
    for (int i = 0; i < 5; i++) {
        User *user = [[User alloc] init];
        user.name = [NSString stringWithFormat:@"更新%d",i];
        user.age = 120+i;
        user.pk = 5+i;
        dispatch_async(dispatch_get_global_queue(0, 0), ^{
            [user update];
        });
    }
}

/**单个子线程批量更新数据,利用事务 */
- (IBAction)updateData:(id)sender {
    dispatch_queue_t q3 = dispatch_queue_create("queue3", NULL);
    dispatch_async(q3, ^{
        NSMutableArray *array = [NSMutableArray array];
        for (int i = 0; i < 500; i++) {
            User *user = [[User alloc] init];
            user.name = [NSString stringWithFormat:@"啊我哦%d",i];
            user.age = 88+i;
            user.pk = 10+i;
            [array addObject:user];
        }
        [User updateObjects:array];
    });
   
}

#pragma mark - 查询
/** 查询单条记录 */
- (IBAction)queryData1:(id)sender {
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSLog(@"第一条:%@",[User findFirstByCriteria:@" WHERE age = 20 "]);
    });
}

/**  条件查询多条记录 */
- (IBAction)queryData2:(id)sender {
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSLog(@"小于20岁:%@",[User findByCriteria:@" WHERE age < 20 "]);
    });
}

/** 查询全部数据 */
- (IBAction)queryData3:(id)sender {
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        NSLog(@"全部:%@",[User findAll]);
    });
}

/** 分页查询数据 */
- (IBAction)queryData:(id)sender {
    static int pk = 5;
    NSArray *array = [User findByCriteria:[NSString stringWithFormat:@" WHERE pk > %d limit 10",pk]];
    pk = ((User *)[array lastObject]).pk;
    NSLog(@"array:%@",array);
}

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
    NSString *title = @"查询";
    int type = 3;
    if ([segue.identifier isEqualToString:@"One"]) {
        title = @"查询一条数据";
        type = 1;
    } else if ([segue.identifier isEqualToString:@"Two"]){
        title = @"条件查询";
        type = 2;
    }else if ([segue.identifier isEqualToString:@"Three"]){
        title = @"查询全部";
        type = 3;
    }else if ([segue.identifier isEqualToString:@"Four"]){
        title = @"分页查询";
        type = 4;
    }
   
    QueryTableViewController *destVC = segue.destinationViewController;
    destVC.title = title;
    destVC.type = type;
}

 
 
如果模型属性中包含数组或者字典,需要做如下操作:
1.模型属性全部用NSString修饰
2.模型属性赋值时
  model.orderHisInfo = [[NSString alloc] initWithData:[UtilitytoJSONData:dic[@"orderHisInfo”]] encoding:NSUTF8StringEncoding]; //查看进程
3.取值时,取出来是数组或者字典
  [Utility toArrayOrNSDictionary:[self.model.orderHisInfo dataUsingEncoding:NSUTF8StringEncoding]];

// 将JSON串转化为字典或者数组  数组转换字符串
+ (id)toArrayOrNSDictionary:(NSData *)jsonData{
    NSError *error = nil;
    id jsonObject = [NSJSONSerialization JSONObjectWithData:jsonData
                                                   options:NSJSONReadingMutableContainers
                                                      error:&error];
   
    if (jsonObject != nil && error == nil){
        return jsonObject;
    }else{
        // 解析错误
        return nil;
    }
   
}

// 将字典或者数组转化为JSON串
+ (NSData *)toJSONData:(id)theData{
   
    NSError *error = nil;
    NSData *jsonData = [NSJSONSerialization dataWithJSONObject:theData
                                                      options:NSJSONWritingPrettyPrinted
                                                         error:&error];
    NSLog(@"%@", jsonData);
   
    if ([jsonData length] != 0 && error == nil){
        return jsonData;
    }else{
        return nil;
    }
}

iOS---基于对Sqlilte3的二次包装的第三次包装--->JKDBModel ,一个好用的离线缓存库的更多相关文章

  1. IOS基于XMPP协议开发--XMPPFramewok框架(三):用户注册

    接着上面说 用户注册是比较简单的,成功连接上服务器后,设置好JID,即可调用 [_xmppStream registerWithPassword:pwd error:&err] 进行注册 -( ...

  2. IOS基于XMPP协议开发--XMPPFramewok框架(一):基础知识

    最近蘑菇街团队的TT的开源,使我对im产生了兴趣,然后在网上找到了XMPPFramework进行学习研究, 并写了以下系列教程供大家参考,有写的不对的地方,请大家多多包涵指正. 目录索引 IOS基于X ...

  3. 基于memcached的单机轻量级通用缓存库minicached的实现

    一.前言 之前拜读过淘宝子柳的<淘宝技术这十年>之大作,深知缓存技术在系统优化中起着一个举足轻重的作用.无论是文件系统静态文件,数据库的访问,乃至网络数据的请求,只要是与内存访问速度相差较 ...

  4. iOS如何获取网络图片(二)

    ios如何获取图片(二)无沙盒下 解决问题 *解决问题1:tableView滑动卡顿,图片延时加载 解决方法:添加异步请求,在子线程里请求网络,在主线程刷新UI *解决问题2:反复请求网络图片,增加用 ...

  5. iOS开发Swift篇—(二)变量和常量

    iOS开发Swift篇—(二)变量和常量 一.语言的性能 (1)根据WWDC的展示 在进行复杂对象排序时Objective-C的性能是Python的2.8倍,Swift的性能是Python的3.9倍 ...

  6. 【基于spark IM 的二次开发笔记】第一天 各种配置

    [基于spark IM 的二次开发笔记]第一天 各种配置 http://juforg.iteye.com/blog/1870487 http://www.igniterealtime.org/down ...

  7. iOS开发CoreAnimation解读之二——对CALayer的分析

    iOS开发CoreAnimation解读之二——对CALayer的分析 一.UIView中的CALayer属性 1.Layer专门负责view的视图渲染 2.自定义view默认layer属性的类 二. ...

  8. 提供基于Lesktop的IM二次开发,联系QQ:87172811

    提供基于Lesktop的IM二次开发,联系QQ:87172811

  9. ASP.NET Core 基于JWT的认证(二)

    ASP.NET Core 基于JWT的认证(二) 上一节我们对 Jwt 的一些基础知识进行了一个简单的介绍,这一节我们将详细的讲解,本次我们将详细的介绍一下 Jwt在 .Net Core 上的实际运用 ...

随机推荐

  1. 数据库优化案例——————某市中心医院HIS系统

    记得在自己学习数据库知识的时候特别喜欢看案例,因为优化的手段是容易掌握的,但是整体的优化思想是很难学会的.这也是为什么自己特别喜欢看案例,今天也开始分享自己做的优化案例. 最近一直很忙,博客产出也少的 ...

  2. Dapper扩展之~~~Dapper.Contrib

    平台之大势何人能挡? 带着你的Net飞奔吧!http://www.cnblogs.com/dunitian/p/4822808.html#skill 上一篇文章:Dapper逆天入门~强类型,动态类型 ...

  3. HashMap与TreeMap源码分析

    1. 引言     在红黑树--算法导论(15)中学习了红黑树的原理.本来打算自己来试着实现一下,然而在看了JDK(1.8.0)TreeMap的源码后恍然发现原来它就是利用红黑树实现的(很惭愧学了Ja ...

  4. 破解SQLServer for Linux预览版的3.5GB内存限制 (UBUNTU篇)

    在上一篇中我提到了如何破解RHEL上SQLServer的内存大小限制,但是Ubuntu上还有一道检查 这篇我将会讲解如何在3.5GB以下内存的Ubuntu中安装和运行SQLServer for Lin ...

  5. iOS 后台处理

    iOS 后台处理的常见用途 1.进入后台时候删除资源:应用处于挂起状态的时候所占用的资源越少,该应用被iOS终止的风险就越低.通过从内存中清理那些易于重新创建的资源,可以增加应用驻留内存的机会,因此可 ...

  6. 手把手教你做个人 app

    我们都知道,开发一个app很大程度依赖服务端:服务端提供接口数据,然后我们展示:另外,开发一个app,还需要美工协助切图.没了接口,没了美工,app似乎只能做成单机版或工具类app,真的是这样的吗?先 ...

  7. 二叉树的递归实现(java)

    这里演示的二叉树为3层. 递归实现,先构造出一个root节点,先判断左子节点是否为空,为空则构造左子节点,否则进入下一步判断右子节点是否为空,为空则构造右子节点. 利用层数控制迭代次数. 依次递归第二 ...

  8. 用 eric6 与 PyQt5 实现python的极速GUI编程(系列04)---- PyQt5自带教程:地址簿(address book)

    [引子] 在PyQt5自带教程中,地址簿(address book)程序没有完全实现界面与业务逻辑分离. 本文我打算用eric6+PyQt5对其进行改写,以实现界面与逻辑完全分离. [概览] 1.界面 ...

  9. mono for android中使用dapper或petapoco对sqlite进行数据操作

    在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.( ...

  10. subline text3 使用总结

    安装:http://www.sublimetext.com/3 插件扩展:  安装package control组件 按Ctrl+`调出console(注:安装有QQ输入法的这个快捷键会有冲突的,输入 ...