iOS-ZFJRedisLib-超便捷的键值对存储方案,Sqlite数据模型存储库,APP缓存解决方案

前言

本人之前写过一个数据模型存储方法,是我在上上家公司作缓存框架的时候写的,具体也就是在FMDB的基础上封装,直接对数据模型进行存储操做,以下:git

《iOS-基于FMDB的操做封装,模型对象的增删改查》github

最近本人也不是很忙,加之在Python项目中用到Redis和在APP中用到NSUserDefaults,我就想作一个便捷的基于数据库的键值对存储方案,固然这个方案并不比Redis优秀,咱们也知道Redis是直接从内存中读取,因此速度方面无法说,可是在APP中咱们不能把键值对放在内存中吧,原本APP的内存就不宽裕!sql

ZFJRedisLib

功能结构

ZFJRedisLib主要包含ZFJRedis和ZFJTable两部分,ZFJRedis主要是用于键值对存储,使用简单方便;ZFJTable主要是对于数据模型进行增删改查操做!所有API以下: 数据库

ZFJRedis

ZFJRedis将会自动在本地建立一个ZFJRedis的表,用于存储键值对数据;数组

1.存取值

字符串-NSString缓存

// NSString
    [ZFJRedis zfj_setValue:@"zhangfujie1128222====" forKey:@"name"];
    // 取值
    NSString *value = [ZFJRedis zfj_valueForKey:@"name"];
    NSLog(@"%@",value);
复制代码

数字对象-NSNumber框架

// NSNumber
    [ZFJRedis zfj_setValue:@(20) forKey:@"age"];
    // 取值
    NSNumber *age = [ZFJRedis zfj_valueForKey:@"age"];
    NSLog(@"%@",age);
复制代码

数组-NSArray学习

// NSArray
    [ZFJRedis zfj_setValue:@[@"111", @(222)] forKey:@"array1"];
    // 取值
    NSArray *array = [ZFJRedis zfj_valueForKey:@"array1"];
    NSLog(@"%@",array);
复制代码

字典-NSDictionaryui

// NSDictionary
    NSDictionary *dict = @{@"name":@"zhangfujie", @"age":@(22), @"sex":@"man"};
    [ZFJRedis zfj_setValue:dict forKey:@"zfj_infors"];
    // 取值
    NSDictionary *dict_value = [ZFJRedis zfj_valueForKey:@"zfj_infors"];
    NSLog(@"%@",dict_value);
复制代码

数据-NSDataspa

// NSData
    NSData *data = [NSJSONSerialization dataWithJSONObject:@[@"aaaaa", @"bbbbb"] options:NSJSONWritingPrettyPrinted error:nil];
    [ZFJRedis zfj_setValue:data forKey:@"arrayData"];
    // 取值
    NSData *data_new = [ZFJRedis zfj_valueForKey:@"arrayData"];
    NSLog(@"data_new == %@",data_new);
复制代码

数据模型-model

// NSObject 数据模型
    ZFJModel *model = [[ZFJModel alloc] init];
    model.name = @"张福杰";
    model.age = 22;
	// 存
    [ZFJRedis zfj_setValue:model forKey:@"model"];
    // 取值
    ZFJModel *model_my = [ZFJRedis zfj_valueForKey:@"model"];
    NSLog(@"%@",model_my.name);
    NSLog(@"%ld",model_my.age);
复制代码

批量存数据

//根据字典赋值
    NSMutableDictionary *value_dict = [[NSMutableDictionary alloc] init];
    [value_dict setValue:@"aaaaaaaa" forKey:@"key_string"];
    [value_dict setValue:@(111) forKey:@"key_number"];
    [value_dict setValue:@[@"wwwwwww11111", @(222)] forKey:@"key_array"];
    [value_dict setValue:@{@"name":@"zhangfujie", @"age":@(22)} forKey:@"key_dict"];
    [value_dict setValue:model_my forKey:@"key_model"];
    [ZFJRedis zfj_setValuesForKeysWithDictionary:value_dict];
复制代码

批量取数据

NSDictionary *dict = [ZFJRedis zfj_dictionaryWithValuesForKeys:value_dict.allKeys];
    NSLog(@"dict == %@",dict);
复制代码

2.查询

获取所有keys

// 获取所有keys
    NSArray *keys = [ZFJRedis zfj_allKeys];
    NSLog(@"keys == %@",keys);
复制代码

获取所有values

// 获取所有values
    NSArray *values = [ZFJRedis zfj_allValues];
    NSLog(@"values == %@",values);
复制代码

获取所有条数

// 获取所有条数
    NSInteger count = [ZFJRedis zfj_count];
    NSLog(@"count == %ld",count);
复制代码

判断key是否存在

// 判断当前key是否存在
    BOOL isExist = [ZFJRedis zfj_isExistkey:@"name"];
    if(isExist){
        NSLog(@"name 存在");
    }else{
        NSLog(@"name 不存在");
    }
复制代码

3.删除

根据key删除

// 删除
    [ZFJRedis zfj_removeObjectForKey:@"array"];
复制代码

根据keys删除

// 根据keys删除数据
    NSArray *key_list = @[@"name", @"age"];
    [ZFJRedis zfj_removeObjectsForKeys:key_list];
复制代码

删除所有

// 删除所有
    [ZFJRedis zfj_removeAllObjects];
复制代码

ZFJTable

ZFJTable是根据数据模型自动建立表,直接根据模型进行增删改查操做的!

1.建立表

// 建立表
    BOOL isScu = [ZFJTable zfj_createTable:[ZFJModel class]];
    if(isScu){
        NSLog(@"ZFJModel表建立成功");
    }else{
        NSLog(@"ZFJModel表建立失败");
    }
复制代码

2.删除表

//删除表
    BOOL isScu = [ZFJTable zfj_removeTable:[ZFJModel class]];
    if(isScu){
        NSLog(@"ZFJModel表删除成功");
    }else{
        NSLog(@"ZFJModel表删除失败");
    }
复制代码

3.删除所有表

// 删除数据库
    BOOL isScu = [ZFJTable zfj_removeAllTables];
    if(isScu){
        NSLog(@"数据库删除成功");
    }else{
        NSLog(@"数据库删除失败");
    }
复制代码

4.插入数据

// 插入一条数据
    ZFJModel *model_0 = [[ZFJModel alloc] init];
    model_0.name = @"张福杰";
    model_0.age = 22;
    model_0.gender = @"男";
    [ZFJTable zfj_insertModel:model_0 completed:^(NSError * _Nonnull error) {
        NSLog(@"error:%@",error);
    }];
    
    // 插入多条数据
    ZFJModel *model_0 = [[ZFJModel alloc] init];
    model_0.name = @"张福杰";
    model_0.age = 22;
    model_0.gender = @"男";

    ZFJModel *model_1 = [[ZFJModel alloc] init];
    model_1.name = @"大白菜";
    model_1.age = 88;
    model_1.gender = @"女";
    NSArray *models = @[model_0, model_1];
    [ZFJTable zfj_insertModels:models completed:^(NSError * _Nonnull error) {
        NSLog(@"error:%@",error);
    }];
复制代码

5.删除数据

// 删除数据
    BOOL isScu = [ZFJTable zfj_deleteModel:[ZFJModel class] where:@"name = '张福杰'"];
    if(isScu){
        NSLog(@"数据删除成功");
    }else{
        NSLog(@"数据删除失败");
    }
复制代码

6.修改数据

// 修改数据
    ZFJModel *model_2 = [[ZFJModel alloc] init];
    model_2.name = @"大白菜";
    model_2.age = 22;
    model_2.gender = @"女";
    [ZFJTable zfj_updateModel:model_2 byKey:@"name" completed:^(NSError * _Nonnull error) {
        NSLog(@"error:%@",error);
    }];
    
    // 修改多条数据
    ZFJModel *model_3 = [[ZFJModel alloc] init];
    model_3.name = @"张福杰";
    model_3.age = 222;
    model_3.gender = @"男男";

    ZFJModel *model_4 = [[ZFJModel alloc] init];
    model_4.name = @"大白菜";
    model_4.age = 222;
    model_4.gender = @"女女";

    NSArray *models = @[model_3, model_4];
    [ZFJTable zfj_updateModels:models byKey:@"name" completed:^(NSError * _Nonnull error) {
        NSLog(@"error:%@",error);
    }];
复制代码

7.数据查询

// 查询所有数据
    [ZFJTable zfj_selectTable:[ZFJModel class] completed:^(NSError * _Nonnull error, NSArray * _Nonnull models) {
        for (ZFJModel *model in models) {
            NSLog(@"%@",model.name);
        }
    }];
    
    // 条件查询
    [ZFJTable zfj_selectTable:[ZFJModel class] where:@"name = '张福杰'" completed:^(NSError * _Nonnull error, NSArray * _Nonnull models) {
        for (ZFJModel *model in models) {
            NSLog(@"%@",model.name);
        }
    }];
    
    // 查询数据条数
    NSInteger count = [ZFJTable zfj_selectTableCount:[ZFJModel class]];
    NSLog(@"count == %ld",count);
    
    // 根据条件查询数量
    NSDictionary *parameters = @{@"name":@"张福杰", @"age":@(22)};
    NSString *sqlStr = @"name = '张福杰' and age = '22'";
    NSInteger count = [ZFJTable zfj_selectTableCount:[ZFJModel class] where:sqlStr];
    NSLog(@"count == %ld",count);
复制代码

8.表扩展字段

// 向某个表添加一个字段
    BOOL isScu = [ZFJTable zfj_addProperty:[ZFJModel class] propertyName:@"newPro_1"];
    if(isScu){
        NSLog(@"字段添加成功");
    }else{
        NSLog(@"字段添加失败");
    }
复制代码

8.错误信息

// 最后一条错误
    NSError *error = [ZFJTable zfj_lastTableError];
    NSLog(@"error == %@",error);
复制代码

源码

DEMO地址:gitee.com/zfj1128/ZFJ…

GitHub地址:github.com/zfjsyqk/ZFJ…

使用教程

  1. pod ‘ZFJRedisLib’
  2. pod install
  3. 导入头文件#import “ZFJRedisHeader.h”

结束语

欢迎各位大佬提供宝贵的建议和意见,也欢迎你们进群933404755或加本人QQ一块儿交流学习!

相关文章
相关标签/搜索