IOS学习笔记28—SQLite3第三方库之FMDB
FMDB主要涉及两个类,FMDatabase和FMResultSet,前者类似于Android中的SQLiteOpenHelper或SQLiteDatabase,FMResultSet类似于Android中的Cursor,用来存储结果集。
下载完FMDB源码后把文件拖到工程中,并导入SQLite支持库,工程目录如下:

然后就是这个Demo的完整截图:

然后就来看看如何操作FMDB:
- //点击按钮后执行保存到数据库的操作
- - (IBAction)saveButtonClicked:(id)sender {
- //获取Document文件夹下的数据库文件,没有则创建
- NSString *docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
- NSString *dbPath = [docPath stringByAppendingPathComponent:@"user.db"];
- //获取数据库并打开
- FMDatabase *database = [FMDatabase databaseWithPath:dbPath];
- if (![database open]) {
- NSLog(@"Open database failed");
- return;
- }
- //创建表(FMDB中只有update和query操作,出了查询其他都是update操作)
- [database executeUpdate:@"create table user (name text,gender text,age integer)"];
- //插入数据
- BOOL insert = [database executeUpdate:@"insert into user values (?,?,?)",nameTextField.text,genderTextField.text,ageTextField.text];
- if (insert) {
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"保存成功" delegate:self cancelButtonTitle:@"确定" otherButtonTitles:nil, nil];
- [alert show];
- [alert release];
- }
- [database close];
- }
操作成功后弹出提示框:

- //点击按钮后执行查询操作
- - (IBAction)queryButtonTapped:(id)sender {
- NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *documentPath = [paths objectAtIndex:0];
- NSString *dbPath = [documentPath stringByAppendingPathComponent:@"user.db"];
- FMDatabase *database = [FMDatabase databaseWithPath:dbPath];
- if (![database open]) {
- return;
- }
- //不需要像Android中那样关闭Cursor关闭FMResultSet,因为相关的数据库关闭时,FMResultSet也会被自动关闭
- FMResultSet *resultSet = [database executeQuery:@"select * from user"];
- while ([resultSet next]) {
- NSString *name = [resultSet stringForColumn:@"name"];
- NSString *gender = [resultSet stringForColumn:@"gender"];
- int age = [resultSet intForColumn:@"age"];
- NSLog(@"Name:%@,Gender:%@,Age:%d",name,gender,age);
- }
- [database close];
- //这里也不需要release
- // [database release];
- }

FMResultSet还支持以下方式获取值:
intForColumn:longForColumn:longLongIntForColumn:boolForColumn:doubleForColumn:stringForColumn:dateForColumn:dataForColumn:dataNoCopyForColumn:UTF8StringForColumnIndex:objectForColumn:
- //执行条件查询操作
- - (IBAction)queryByConditionBtnTapped:(id)sender {
- NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *docPath = [paths objectAtIndex:0];
- NSString *dbPath = [docPath stringByAppendingPathComponent:@"user.db"];
- FMDatabase *database = [FMDatabase databaseWithPath:dbPath];
- if (![database open]) {
- return;
- }
- FMResultSet *resultSet = [database executeQuery:@"select * from user where name = ?",@"Ryan"];
- while ([resultSet next]) {
- NSString *name = [resultSet stringForColumn:@"name"];
- NSString *gender = [resultSet stringForColumn:@"gender"];
- int age = [resultSet intForColumn:@"age"];
- NSLog(@"Name:%@,Gender:%@,Age:%d",name,gender,age);
- }
- [database close];
- }

- //执行更新操作
- - (IBAction)updateBtnTapped:(id)sender {
- NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *docPath = [paths objectAtIndex:0];
- NSString *dbPath = [docPath stringByAppendingPathComponent:@"user.db"];
- FMDatabase *database = [FMDatabase databaseWithPath:dbPath];
- if (![database open]) {
- return;
- }
- //参数必须是NSObject的子类,int,double,bool这种基本类型,需要封装成对应的包装类才可以
- BOOL update = [database executeUpdate:@"update user set name = ? where age = ?",@"RyanTang",[NSNumber numberWithInt:24]];
- if(update){
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"更新成功" delegate:self cancelButtonTitle:@"确定" otherButtonTitles:nil, nil];
- [alert show];
- [alert release];
- }
- [database close];
- }

- //执行删除操作
- - (IBAction)deleteBtnTapped:(id)sender {
- NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *docPath = [paths objectAtIndex:0];
- NSString *dbPath = [docPath stringByAppendingPathComponent:@"user.db"];
- FMDatabase *database = [FMDatabase databaseWithPath:dbPath];
- if (![database open]) {
- return;
- }
- BOOL delete = [database executeUpdate:@"delete from user where name = ?",@"Tang"];
- if (delete) {
- UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"删除成功" delegate:self cancelButtonTitle:@"确定" otherButtonTitles:nil, nil];
- [alert show];
- [alert release];
- }
- [database close];
- }

如果我们的app需要多线程操作数据库,那么就需要使用FMDatabaseQueue来保证线程安全了。切记不能在多个线程中共同一个FMDatabase对象并且在多个线程中同时使用,这个类本身不是线程安全的,这样使用会造成数据混乱等问题。
使用FMDatabaseQueue很简单,首先用一个数据库文件地址来初使化FMDatabaseQueue,然后就可以将一个闭包(block)传入inDatabase方法中。在闭包中操作数据库,而不直接参与FMDatabase的管理。
- -(void)executeDBOperation
- {
- //获取Document文件夹下的数据库文件,没有则创建
- NSString *docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
- NSString *dbPath = [docPath stringByAppendingPathComponent:@"user.db"];
- FMDatabaseQueue *databaseQueue = [FMDatabaseQueue databaseQueueWithPath:dbPath];
- [databaseQueue inDatabase:^(FMDatabase *db){
- [db executeUpdate:@"insert into user values (?,?,?)",@"Ren",@"Male",[NSNumber numberWithInt:20]];
- }];
- [databaseQueue close];
- }
工程源码:下载
转载:http://blog.csdn.net/ryantang03/article/details/7875464
IOS学习笔记28—SQLite3第三方库之FMDB的更多相关文章
- python3.4学习笔记(八) Python第三方库安装与使用,包管理工具解惑
python3.4学习笔记(八) Python第三方库安装与使用,包管理工具解惑 许多人在安装Python第三方库的时候, 经常会为一个问题困扰:到底应该下载什么格式的文件?当我们点开下载页时, 一般 ...
- robot framework学习笔记之十一--第三方库requests详解
一.安装 Requests 通过pip安装 pip install requests 或者,下载代码后安装: $ git clone git://github.com/kennethreitz/req ...
- iOS学习笔记16-数据库SQLite
一.数据库 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等.离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式: 归档:NSKeyedArchiver 偏好设置:NSU ...
- IOS学习笔记48--一些常见的IOS知识点+面试题
IOS学习笔记48--一些常见的IOS知识点+面试题 1.堆和栈什么区别? 答:管理方式:对于栈来讲,是由编译器自动管理,无需我们手工控制:对于堆来说,释放工作由程序员控制,容易产生memor ...
- iOS学习笔记20-地图(二)MapKit框架
一.地图开发介绍 从iOS6.0开始地图数据不再由谷歌驱动,而是改用自家地图,当然在国内它的数据是由高德地图提供的. 在iOS中进行地图开发主要有三种方式: 利用MapKit框架进行地图开发,利用这种 ...
- iOS学习笔记17-FMDB
上一节我已经介绍了SQLite的简单使用,不了解的可以提前去看一下iOS学习笔记16-数据库SQLite,这节我们来讲下FMDB. 一.FMDB介绍 FMDB是一种第三方的开源库,FMDB就是对SQL ...
- iOS学习笔记17-FMDB你好!
上一节我已经介绍了SQLite的简单使用,不了解的可以提前去看一下iOS学习笔记16-数据库SQLite,这节我们来讲下FMDB. 一.FMDB介绍 FMDB是一种第三方的开源库,FMDB就是对SQL ...
- IOS学习笔记25—HTTP操作之ASIHTTPRequest
IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...
- iOS学习笔记-精华整理
iOS学习笔记总结整理 一.内存管理情况 1- autorelease,当用户的代码在持续运行时,自动释放池是不会被销毁的,这段时间内用户可以安全地使用自动释放的对象.当用户的代码运行告一段 落,开始 ...
随机推荐
- Java多态和动态绑定是如何实现的
最近深入学习java,看到了动态绑定和多态这一章节,但遗憾的是,大部分的相关文章都停留于表面文字的描述.不得已,最后google了几篇英文文章,在此总结下这个问题. 一.静态绑定和动态绑定的区别 在J ...
- 关于org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor的队列
今天查看源码发现spring的线程池是支持队列的: 并且队列支持的上限相当大: 当线程池的达到最大线程时,默认会把任务放在队列(内存)中,所以我们可以放心用这个东西来写日志了
- jrebel 7免费激活(非破解) 和 IntelliJ Idea 2017 免费激活方法
转自http://www.cnblogs.com/suiyueqiannian/p/6734412.html http://www.cnblogs.com/suiyueqiannian/p/67540 ...
- min-height clear
在编辑页面时,总是会遇到min-height的设置 但是设置min-height后下面的div总是 跟随min-height的高度有些漂浮,如果不想让下面的div没有漂浮的效果 可以用到样式 clea ...
- php面象对象魔术方法的使用
class Moshu{ public $number; public function __construct($str)//构造方法,new实例时,自动调用 { //require('/confi ...
- Atitit.atiJsBridge 新特性v7q329
Atitit.atiJsBridge 新特性v7q329 atiJsBridge 未来计划 Postdata 图像上传的支持 Simp param计划 p1 p2 p3 p4 $method 的si ...
- Android ART介绍
1.ART之所以会比Dalvik快,是由于ART运行的是本地机器指令,而Dalvik运行的是Dex字节码.通过通过解释器运行. 虽然Dalvik也会对频繁运行的代码进行JIT生成本地机器指令来运行,但 ...
- MongoDB 将Json数据直接写入MongoDB的方法
Json转Bson MongoDB中是以Bson数据格式进行存储的,Json字符串没有办法直接写入MongoDB 可以将Json字符串转换成DBObject或者Document,然后写入MongoDB ...
- 655. Big Integer Addition【easy】
Given two non-negative integers num1 and num2 represented as string, return the sum of num1 and num2 ...
- Dijkstra普通算法及优先队列优化
#include<stdio.h> #include<iostream> #define maxv 100 #define inf 0x3fffffff using names ...