iOS开发中使用FMDB

前言

SQLite
(http://www.sqlite.org/docs.html)
是一个轻量级的关周详据库。iOS SDK 很已经匡助了
SQLite,在动用时,只需求进入 libsqlite3.dylib 依赖以及引入 sqlite3.h
头文件即可。可是,原生的 SQLite API
在采用上一对一不谐和,在使用时,极度艰难。于是,开源社区中就出现了一密密麻麻将
SQLite API 举办包装的库,而 FMDB
(https://github.com/ccgus/fmdb)
则是开源社区中的特出者。

FMDB 在选用上极度便利。以下是一个概括的例子:

可以见见,使用 FMDB 后的数据库代码清晰明了,比原生的 API
优雅多了。别的,FMDB 同时匹配 ARC 和非 ARC
工程,会活动依照工程布署来调整有关的内存管理代码。


应用表达

该利用表达主要翻译自 fmdb 的 github
项目表明文档:https://github.com/ccgus/fmdb

引入相关文件

首先将 FMDB 从 github 上 clone 下来,然后将以下文件 copy 到您的工程中:

确立数据库

树立数据库只须要如下一行即可 , 当该公文不设有时,fmdb
会本身创建一个。即便你传入的参数是一贫如洗:@“” ,则 fmdb
会在临时文件目录下开创那些数据库,如若你传入的参数是
NULL,则它会确立一个在内存中的数据库。

FMDatabase*db=[FMDatabasedatabaseWithPath:@”/tmp/tmp.db”];

开拓数据库

使用如下语句,若是打开失利,恐怕是权力不足大概资源不足。日常打开完操作操作后,要求调用
close 方法来关闭数据库。

施行更新操作

除了 Select
操作之外,其他的都是立异操作。更新操作使用如下方法,即便有不当,可以用
error 参数中赢得。

-[FMDatabaseexecuteUpdate:error:withArgumentsInArray:orVAList:]

施行查询操作

询问操作示例如下。注意:尽管操作结果只有一行,也亟需先调用 FMResultSet
的 next 方法。

FMDB 提供如下多少个艺术来获取差距品种的多寡:

常见景况下,你并不需求关闭
FMResultSet,因为有关的数据库关闭时,FMResultSet 也会被自动关闭。

多少参数

一般情形下,你可以遵从规范的 SQL 语句,用 ? 表示执行语句的参数,如:

INSERTINTOmyTableVALUES(?,?,?)

下一场,可以我们得以调用 executeUpdate 方法来将 ?
所替代的有血有肉参数传入,常常是用变长参数来传递进入的,如下:

NSString*sql=@”insert into User (name, password) values (?,
?)”;[dbexecuteUpdate:sql,user.name,user.password];

此地供给专注的是,参数必须是 NSObject 的子类,所以象 int,double,bool
那种基本项目,需求封装成对应的包装类才行,如下所示:

线程安全

一旦我们的 app 要求二十多线程操作数据库,那么就必要利用 FMDatabaseQueue
来保证线程安全了。 切记无法在三个线程中一块一个 FMDatabase
对象并且在七个线程中还要选择,那个类本人不是线程安全的,那样使用会导致数据错乱等难题。

应用 FMDatabaseQueue 很简单,首先用一个数据库文件地方来初使化
FMDatabaseQueue,然后就足以将一个闭包 (block) 传入 inDatabase 方法中。
在闭包中操作数据库,而不直接参加 FMDatabase 的田间管理。

工具

为了查看 Sqlite
中的数据,一个好的图形化界面的数据库管理程序是需求的。mysql 有
phpMyAdmin,那么 sqlite 呢?

自个儿最紧要采用的是 Firefox 的一个名为 SQLite Manager
的插件,安装此插件后,可以平素打开后缀名为 sqlite 的数据库文件。SQLite
Manager 提供一个图形化的界面来执行多少查询或转移操作。如下图所示:

总结

FMDB 将 SQLite API 举行了很谈得来的卷入,使用上万分方便,对于那几个运用纯
Sqlite API 来进行数据库操作的 app,可以考虑将其搬迁到基于 FMDB
上,那对于未来数据库相关功能的支付保养,可以增长广大功能。


天命据量,高并发时,经常接纳sqlite3作为数据库;而接纳fmdb管理越发简明有效!


iOS/Mac
开发博客列表(不断更新中)

作为一个iOS开发要看的网站,一定对您有效的,相信我!

进步iOS开发功能的艺术和工具

网站地图xml地图