美文网首页IOS swift 日常功能
iOS用对FMDB的超好用封装

iOS用对FMDB的超好用封装

作者: scubers | 来源:发表于2016-05-26 12:19 被阅读3727次

一个对FMDB进行类Hibernate封装的iOS库,支持Objective-C 和 Swift。

GitHub: https://github.com/scubers/JRDB

Feedback: jr-wong@qq.com


Description

  • 使用分类的模式,模仿Hibernate,对FMDB进行简易封装
  • 支持pod 安装 『pod 'JRDB'』,Podfile需要添加 use_framework!
  • 使用协议,不用继承基类,对任意NSObject可以进行入库操作
  • 支持swift 和 Objective-C
  • 支持数据类型:基本数据类型(int,double,等),String,NSData,NSNumber,NSDate
    • 注:swift的基本数据类型,不支持Option类型,既不支持Int?Int!等,对象类型支持Option类型

Installation 【安装】

use_frameworks!
pod 'JRDB'
@import JRDB;

Usage

Save 【保存】

  • OC
Person *p = [[Person alloc] init];
p.a_int = 1;
p.b_unsigned_int = 2;
p.c_long = 3;
p.d_long_long = 4;
p.e_unsigned_long = 5;
p.f_unsigned_long_long = 6;
p.g_float = 7.0;
p.h_double = 8.0;
p.i_string = @"9";
p.j_number = @10;
p.k_data = [NSData data];
p.l_date = [NSDate date];
[p jr_save];
  • Swift
    • Swift中需要入库的类需要继承NSObject(使用到runtime)
    • The Object that you want to persistent should inherit from NSObject
let p = Person()
p.name = "name"
p.age = 10
p.birthday = NSDate()
p.jr_save()

Update 【更新】

Person *p = [Person jr_findAll].firstObject;
p.name = @"abc";
[p jr_update columns:nil];
column: 需要更新的字段名,传入空为全量更新

--

Delete 【删除】

Person *p = [Person jr_findAll].firstObject;
[p jr_delete];

--

Select 【查找】

  • 常规查找
Person *P = [Person jr_findByID:@"111"];
NSArray *list = [Person jr_findAll];
NSArray *list1 = [Person jr_findAllOrderBy:@"_age" isDesc:YES];
  • 条件查询
NSArray *condis = @[
                    [JRQueryCondition condition:@"_l_date < ?" args:@[[NSDate date]] type:JRQueryConditionTypeAnd],
                    [JRQueryCondition condition:@"_a_int > ?" args:@[@9] type:JRQueryConditionTypeAnd],
                    ];
    
NSArray *arr = [Person jr_findByConditions:condis
                                   groupBy:@"_room"
                                   orderBy:@"_age"
                                     limit:@" limit 0,13 "
                                    isDesc:YES];
  • SQL
NSString *sql = @"select * from Person where age = ?";
NSArray *list = [Person jr_executeSql:sql args:@[@10]];

Other 【其他】

协议:JRPersistent

@protocol JRPersistent <NSObject>
@required
- (void)setID:(NSString *)ID;
- (NSString *)ID;
@optional
/**
 *  返回不用入库的对象字段数组
 *  The full property names that you want to ignore for persistent
 *  
 *  @return array
 */
+ (NSArray *)jr_excludePropertyNames;
@end

默认NSObject分类实现

@interface NSObject (JRDB) <JRPersistent>
(...methods)
@end

JRDBMgr

@interface JRDBMgr : NSObject
@property (nonatomic, strong) FMDatabase *defaultDB;
+ (instancetype)shareInstance;
+ (FMDatabase *)defaultDB;
- (FMDatabase *)createDBWithPath:(NSString *)path;
- (void)deleteDBWithPath:(NSString *)path;
/**
 *  在这里注册的类,使用本框架的数据库将全部建有这些表
 *  @param clazz 类名
 */
- (void)registerClazzForUpdateTable:(Class<JRPersistent>)clazz;
- (NSArray<Class> *)registedClazz;
/**
 * 更新默认数据库的表(或者新建没有的表)
 * 更新的表需要在本类先注册
 */
- (void)updateDefaultDB;
- (void)updateDB:(FMDatabase *)db;
@end

JRDBMgr持有一个默认数据库(~/Documents/jrdb/jrdb.sqlite),任何不指定数据库的操作,都在此数据库进行操作。默认数据库可以自行设置。

Method
- (void)registerClazzForUpdateTable:(Class<JRPersistent>)clazz;

在JRDBMgr中注册的类,可以使用

-(void)updateDB:(FMDatabase *)db

进行统一更新或者创建表。


Table Operation 【表操作】

Create 【建表】

// FMDatabase+JRDB 方法
[[JRDBMgr defaultDB] createTable4Clazz:[Person class]];
[Person jr_createTable];

// 删除原有的表,重新创建
[[JRDBMgr defaultDB] truncateTable4Clazz:[Person class]];
[Person jr_truncateTable];

//保存时,若发现没有表,将自动创建
[person jr_save];

Update 【更新表】

[[JRDBMgr defaultDB] updateTable4Clazz:[Person class]];
[Person jr_updateTable];

更新表时,只会添加不存在的字段,不会修改字段属性,不会删除字段,若有需要,需要自行写sql语句进行修改

Drop 【删表】

[[JRDBMgr defaultDB] dropTable4Clazz:[Person class]];
[Person jr_dropTable];

Thread Operation 【线程操作】

  • 多线程操作使用FMDB自带的 FMDatabaseQueue
[person jr_saveWithComplete:^(BOOL success) {
    NSLog(@"%d", success);
}];

任何带complete block的操作,都将放入到FMDatabaseQueue进行顺序执行

  • 注:所有需要立刻返回结果,或者影响其他操作的数据库操作,都建议放在主线程进行更新,大批量更新以及多线程操作数据库时,请使用带complete block的操作。

MoreUsage

  • 查看FMDatabase+JRDB.h

相关文章

  • JRDB:iOS对FMDB的超好用封装

    JRDB:iOS对FMDB的超好用封装 JRDB:iOS对FMDB的超好用封装

  • iOS用对FMDB的超好用封装

    一个对FMDB进行类Hibernate封装的iOS库,支持Objective-C 和 Swift。 GitHub:...

  • JRDB:iOS对FMDB的超好用封装

    原文地址:http://www.cocoachina.com/ios/20160531/16507.html 在开...

  • iOS FMDB 数据库

    FMDB 1、简述: * FMDB是iOS平台的SQLite数据库框架,是对libsqlite3框架的封装 * F...

  • 12.第三方源码-FMDB

    1、简述: FMDB是iOS平台的SQLite数据库框架,是对libsqlite3框架的封装 FMDB以OC的方式...

  • SQLite数据库框架--FMDB

    FMDB概述 什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite...

  • FMDB学习

    FMDB简介 FMDB是什么 FMDB是iOS平台的SQLite数据库框架,它用object-c封装了SQLite...

  • SQLite数据库框架之FMDB(Swift)

    FMDB使用 FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API ...

  • FMDB

    # FMDB基本使用 FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言...

  • 2019-06-13

    FMDB介绍 FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API ...

网友评论

  • 雨影:*** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'class: JDClockModel should be registered in JRDBMgr'
    scubers:未注册,文档有写必须先注册再使用
  • 741bfa92d034:楼主你好,请问有交流群吗?我这个项目可能要用你这个封装的框架,有些问题要向你请教
    scubers:暂时还没创建交流群,如果使用,建议自己创建中间层,再调用我的库
  • 等这姑娘老在我心里:储存 一对多关系时 储存不上怎么办
    scubers:@等这姑娘老在我心里 方便贴出您的mode的代码吗?
  • 等这姑娘老在我心里:我想问一下 JRQueryCondition 里面args 是不是会带入到前面的 ?中去
    scubers:只会替代前面的问号占位符,不会替换C的各种占位符

本文标题:iOS用对FMDB的超好用封装

本文链接:https://www.haomeiwen.com/subject/amqxdttx.html