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,当用户的代码在持续运行时,自动释放池是不会被销毁的,这段时间内用户可以安全地使用自动释放的对象.当用户的代码运行告一段 落,开始 ...
随机推荐
- 中国版Azure支持那些版本号Linux
不在下述列表中的Linux表示尚未经过正式验证,并不意味着不能使用,客户能够通过自行上传镜像文件的方式使用其它Linux版本号,可是不保证是否遇到一些驱动或者兼容问题. 分发 版本号 上次验证时间 驱 ...
- java 状态对象
package cn.itcast.hibernate.sh.state; import org.hibernate.Session; import org.hibernate.Transaction ...
- sqlite 小刀 初试
SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且目前已经在很多嵌入式产 ...
- C#7.0之元组数据
static (string,string,string) LookupName(int a) { return ("","",""); } ...
- docker容器互连
三种方式 1.使用容器连接的示例如下: $ docker run --name some-app --link itbilu-mysql:mysql -d application-that-uses- ...
- C#颜色 Color.FromArgb ColorTranslator 16进制
//方法1: //引用命名空间 using System.Drawing; 16进制颜色代码转Color类型:ColorTranslator.FromHtml(color); Color类型转16进制 ...
- NanoHttpd
NanoHttpd是个很强大的开源库,仅仅用一个Java类,就实现了一个轻量级的 Web Server,可以非常方便地集成到Android应用中去,让你的App支持 HTTP GET, POST, P ...
- [svc][jk]监控jvm的一个坑
监控jvm的一个坑 1,遇到的问题 我按照以往文档,在catalina.sh里追加jvm的监控api,如下 紧接着我启动 tomcat. 未报任何错误. 发现 lsof –i:12000, 12000 ...
- instancetype 对比 id 的好处
转自:http://blog.csdn.net/yangzychina/article/details/8818941 今天研究代码的时候,发现居然返回 instancetype 类型,很惊讶自己学识 ...
- Java Annotations, Java Reflection, and Java Test Runner
www.vogella.com/tutorials/JavaAnnotations/article.html