转载值得观看ios开发资源收集

FMDB 二次封装,面向模型

2016-11-21  本文已影响2784人  gitKong

最新针对 FMDatabaseQueue封装 如果你需要多线程处理数据库,用这个就轻松处理

一、FMDB简单介绍

FMDB是OC的方式封装了SQLite的C语言API,并且它对于多线程的并发操作进行了处理,所以是线程安全的;相对系统提供的CoreData,轻量好多,使用起来也很方便,除查询以外的所有操作,都称为“更新”,这里就不详细介绍了,不是本文的主题

二、为什么要再封装?

因此封装面向模型,只需要传入对应的模型信息就能进行数据库操作,不需要写任何SQL语句,屏蔽内部所有操作,插入什么模型,就取出什么模型,简单易用!同时为了保证传入的都是模型数据,添加了异常提示,对传入的模型做了限制,必须是NSObject或者NSObject的子类,同时不响应事件

因此操作异常时添加断言,准确定位操作异常位置以及异常情况

因此将关闭数据库操作封装在框架中,此时调用不需要关心数据库的关闭

三、API介绍(增删改查)

单例模式,项目中唯一,方便管理,传入数据库名称,后续操作不同的数据库

/**
 *  @author Clarence
 *
 *  单例创建,项目唯一
 */
+ (instancetype)shareManager:(NSString *)fl_dbName;

创表,外界传入指定的类,工具会根据类来创建表,如果此时表已经存在,则跳过,没有才去创建,执行完这个操作后自动关闭数据库,释放内存

#pragma mark -- 创表

/**
 *  @author Clarence
 *
 *  根据类名创建表,如果有则跳过,没有才创建,执行完毕后自动关闭数据库
 
 *  @return YES表示创建表格操作执行成功 或者 表格已经存在,NO则失败
 */
- (BOOL)fl_createTable:(Class)modelClass;

插入数据,可以传入单个模型,或者传入模型数组,此时内部处理了,遍历数组插入的期间数据库不会关闭,直到所有插入完毕后才关闭数据库;同时,如果传入的模型的FLDBID在对应表中已经存在,则执行更新操作,保证FLDBID对应数据的唯一性

#pragma mark -- 插入

/**
 *  @author Clarence
 *
 *  @param model 插入单个模型或者模型数组,如果此时传入的模型对应的FLDBID在表中已经存在,则替换更新旧的
 *  如果没创建表就自动先创建,表名为模型类名
 *  此时执行完毕后自动关闭数据库
 
 *  @return YES表示创建表格操作执行成功 或者 表格已经存在,NO则失败
 */
- (BOOL)fl_insertModel:(id)model;

查询 提供三个方法

#pragma mark -- 查询
/**
 *  @author Clarence
 *
 *  查询指定表是否存在,执行完毕后自动关闭数据库
 
 *  @return YES表示操作执行成功并且 modelClass 表格存在,NO则操作失败或者 modelClass 表格不存在
 */
- (BOOL)fl_isExitTable:(Class)modelClass;
/**
 *  @author Clarence
 *
 *  查找指定表中指定DBID的模型,执行完毕后自动关闭数据库
 
 *  @return 不等于nil,表示查询数据操作执行成功并有数据,返回查询成功的模型数据,nil则表示查询操作失败 或者 查询成功但数据为空 或者 对应的表格不存在
 */
- (id)fl_searchModel:(Class)modelClass byID:(NSString *)FLDBID;
/**
 *  @author Clarence
 *
 *  查找指定表中模型数组(所有的),执行完毕后自动关闭数据库
 
 *  @return 不等于nil,表示查询数据操作执行成功并有数据,返回查询成功的模型数据,nil则表示查询操作失败 或者 查询成功但数据为空 或者 对应的表格不存在
 */
- (NSArray *)fl_searchModelArr:(Class)modelClass;

修改 根据指定FLDBID,将新传入的模型替换旧的模型数据,执行完毕后自动关闭数据库,如果没有对应表,会有断言

#pragma mark -- 修改

/**
 *  @author Clarence
 *
 *  修改指定DBID的模型,执行完毕后自动关闭数据库
 
 *  @return YES表示更新操作执行成功,NO则操作失败 或者 对应的表格不存在
 */

- (BOOL)fl_modifyModel:(id)model byID:(NSString *)FLDBID;

删除,此时也提供了三个方法

#pragma mark -- 删除
/**
 *  @author Clarence
 *
 *  删除指定表,执行完毕后自动关闭数据库
 
 *  @return YES表示删除操作执行成功,NO则操作失败 或者 对应的表格不存在
 */
- (BOOL)fl_dropTable:(Class)modelClass;
/**
 *  @author Clarence
 *
 *  删除指定表格的所有数据,执行完毕后自动关闭数据库
 
 *  @return YES表示删除操作执行成功,NO则操作失败 或者 对应的表格不存在 或者 没有对应数据可以删除
 */
- (BOOL)fl_deleteAllModel:(Class)modelClass;
/**
 *  @author Clarence
 *
 *  删除指定表中指定DBID的模型,执行完毕后自动关闭数据库
 
 *  @return YES表示删除操作执行成功,NO则操作失败 或者 对应的表格不存在 或者 没有对应数据可以删除
 */
- (BOOL)fl_deleteModel:(Class)modelClass byId:(NSString *)FLDBID;
/**
 *  @author gitKong
 *
 *  删除数据库
 
 *  @return 操作不涉及到数据库操作 YES 表示删除成功,NO则删除失败
 */
- (BOOL)fl_dropDB;

四、调用以及效果图(只举部分例子,详细请移步gitHub,有完整的Demo介绍)

 [FLFMDBMANAGER fl_insertModel:arrM];
[FLFMDBMANAGER fl_deleteModel:[FLStudentModel class] byId:model.FLDBID]
[[FLFMDBManager shareManager] fl_modifyModel:model byID:model.FLDBID]
[FLFMDBMANAGER fl_searchModel:[FLStudentModel class] byID:textField.text]
FMDB封装效果.gif

五、使用注意点

六、小总结

define FLFMDBMANAGER [FLFMDBManager shareManager:FLDB_DEFAULT_NAME]

define FLFMDBMANAGERX(DB_NAME) [FLFMDBManager shareManager:DB_NAME]


- *技术上实现并没多难,使用runtime就很容易获取当前模型类中的属性,关键还是处理一系列逻辑,代码比较简单,这里就不详细讲解了,Demo中有相对应的注释 !*

- *每个人都有自己的编程想法和爱好,有人喜欢面向字典开发、有人喜欢面向模型开发,我就喜欢面向模型封装,屏蔽内部处理逻辑,调用只需要一句代码,享受封装的过程~*

- *最后,还是那句,如果你有什么问题或者建议,尽管留言,欢迎大家关注我,喜欢就给个like 和 star,随时更新!谢谢支持!*

- ##[gitHub地址](https://github.com/gitkong/FLFMDBManager),欢迎star
上一篇 下一篇

猜你喜欢

热点阅读