iOS FMDB
FMDB
FMDB概述
什么是FMDB
* FMDB是iOS平台的SQLite数据库框架
* FMDB以OC的方式封装了SQLite的C语言API
FMDB的优点
* 使用起来更加面向对象,省去了很多麻烦、冗余的C语言代码
* 对比苹果自带的Core Data框架,更加轻量级和灵活
* 提供了多线程安全的数据库操作方法,有效地防止数据混乱
FMDB的github地址
* https://github.com/ccgus/fmdb
FMDB基本使用
FMDB有三个核心类
FMDatabase
* 一个FMDatabase对象就代表一个单独的SQLite数据库 用来执行SQL语句
FMResultSet
* 使用FMDatabase执行查询后的结果集
FMDatabaseQueue
* 用于在多线程中执行多个查询或更新,它是线程安全的
FMDB打开数据库
通过指定SQLite数据库文件路径来创建FMDatabase对象
FMDatabase *db = [FMDatabase databaseWithPath:path];
if (![db open]) {
NSLog(@"数据库打开失败!");
}
文件路径(path)有三种情况:
* 具体文件路径
* 如果不存在会自动创建
* 空字符串@""
* 会在临时目录创建一个空的数据库
* 当FMDatabase连接关闭时,数据库文件也被删除
* nil
* 会创建一个内存中临时数据库
* 当FMDatabase连接关闭时,数据库会被销毁
执行更新
在FMDB中,除查询以外的所有操作,都称为“更新”create、drop、insert、update、delete等
* 使用executeUpdate:方法执行更新 - (BOOL)executeUpdate:(NSString*)sql, ...
* - (BOOL)executeUpdateWithFormat:(NSString*)format, ...
* - (BOOL)executeUpdate:(NSString*)sql withArgumentsInArray:(NSArray *)arguments
*
* 示例 [db executeUpdate:@"UPDATE t_student SET age = ? WHERE name = ?;", @20, @"Jack"]
*
执行查询
查询方法
- (FMResultSet *)executeQuery:(NSString*)sql, ...
- (FMResultSet *)executeQueryWithFormat:(NSString*)format, ...
- (FMResultSet *)executeQuery:(NSString *)sql withArgumentsInArray:(NSArray *)arguments
* 示例 // 查询数据
* FMResultSet *rs = [db executeQuery:@"SELECT * FROM t_student"];
*
* // 遍历结果集
* while ([rs next]) {
* NSString *name = [rs stringForColumn:@"name"];
* int age = [rs intForColumn:@"age"];
* double score = [rs doubleForColumn:@"score"];
* }
* FMDatabaseQueue
* FMDatabase这个类是线程不安全的,如果在多个线程中同时使用一个FMDatabase实例,会造成数据混乱等问题.
* 为了保证线程安全,FMDB提供方便快捷的FMDatabaseQueue类
* FMDatabaseQueue的创建 FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:path];
*
* 简单使用 [queue inDatabase:^(FMDatabase *db) {
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Jack"];
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Rose"];
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Jim"];
*
* FMResultSet *rs = [db executeQuery:@"select * from t_student"];
* while ([rs next]) {
* // …
* }
* }];
*
* 使用事务 [queue inTransaction:^(FMDatabase *db, BOOL *rollback) {
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Jack"];
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Rose"];
* [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"Jim"];
*
* FMResultSet *rs = [db executeQuery:@"select * from t_student"];
* while ([rs next]) {
* // …
* }
* }];
*
* 事务回滚 rollback = YES;
FMDB的下载地址: https://github.com/ccgus/fmdb
iOS FMDB的更多相关文章
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- IOS FMDB 获取数据库表和表中的数据
ios开发中,经常会用到数据库sqlite的知识,除了增,删,改,查之外,我们说说如何获取数据库中有多少表和表相关的内容. 前言 跟数据库使用相关的一般的增删改查的语句,这里就不做解释了.在网上有很多 ...
- iOS FMDB 不需要关闭
以前做了一个应用,里面用到了FMDB,进行每一次操作前,都open,完成操作后都close.因为我是参考他们以前的代码.程序初期没发现什么问题,程序完成后,各种卡顿就出现了!即使我是放在新线程里操作的 ...
- iOS FMDB的使用
简介: SQLite (http://www.sqlite.org/docs.html) 是一个轻量级的关系数据库.iOS SDK 很早就支持了 SQLite,在使用时,只需要加入 libsqlite ...
- iOS | FMDB快速上手
任何的开发都或多或少的接触到数据库,而在IOS中一般使用的是SQLite数据库,这是一个轻量功能较为不错的数据库.而现在用到比较多的第三方数据库操作框架就是FMDB.废话不多说,相信查找到这篇文章的都 ...
- iOS FMDB小试了一下
今天从早上9点,一直在看FMDB,知道中午11:40.我的效率是不是很低下.中间也碰到了几个小bug. 虽然做了一个小demo,但是觉得还比不上在项目中使用中锻炼的多,先暂且一总结. 先下载FMDB的 ...
- iOS FMDB官方使用文档 G-C-D的使用 提高性能(翻译)(转)
由于FMDB是建立在SQLite的之上的,所以你至少也该把这篇文章从头到尾读一遍.与此同时,把SQLite的文档页 http://www.sqlite.org/docs.html 加到你的书签中.自动 ...
- IOS FMDB模糊查询
http://blog.sina.com.cn/s/blog_9630f1310101fx1d.html /查询记录 -(NSArray*)selectitemDream_desc:(JiemengS ...
- iOS FMDB的是使用和注意事项
1.FMDB 默认的使用方法不是线程安全的. 2.Sqlite 默认不支持外键. 3.Sqlite 不支持用 ALTER 关键字给已有表添加外键约束 解决: 1.FMDBDatabaseQueue 2 ...
随机推荐
- Silverlight Application 无法调用js的方法
今天下午做项目的时候遇到了这个错误 找了很多原因没找出,在蛋疼之际找出了问题, Silverlight调js方法的时候 js方法里面不能出现一点问题,如果有一点问题就会报这个错误.
- Django中ModelForm应用
Django中ModelForm的应用 在传统中Form提交的POST的数据在服务器端获取时将不得不一一获取并验证数据的可靠性,但是使用django提供的Form时可简化该过程并提供相应的验证,同时D ...
- vs中动态DLL与静态LIB工程中加入版本信息的方法
说明:本文仅针对刚接触VS不久的新手们(包括ME),提供的一点小Tips,同时也是小生的首篇Blog文章,请大伙多多担待O(∩_∩)O哈! 步骤1 - 在工程中右键添加新建项 步骤2 - 选择创建RC ...
- 自定义tableviewCell的分割线
第一种:addsubview UIView *line = [[UIView alloc]initWithFrame:CGRectMake(10, cellH-0.5, DEVW-10, 0.5)]; ...
- Retrieving the COM class factory for component with CLSID XX failed due to the following error: 80070005 拒绝访问。
环境及异常信息说明 环境说明: Win2008 R2 企业版 x64 .IIS 7.0 功能说明:服务端操作Excel,(上传Excel到服务器,并在服务器端读取Excel中的数据) 异常信息:Ret ...
- ZendFramework2 源码分析 index.php
<?php /** * This makes our life easier when dealing with paths. Everything is relative * to the a ...
- bootstrap的datetimepicker控件只选择年月的配置
<script src="{% static "jquery/jquery-1.11.3.min.js" %}"></script> & ...
- USB Mass Storage学习笔记-STM32+FLASH实现U盘
一.内容概述 采用STM32内部自带USB控制器外加大页NAND FLASH K9F1G08U0A实现一个128M的U盘. 1.STM32的USB控制器 STM32F103的MCU自带USB从控制器 ...
- 激活前一个程序(注册全局消息,使用Mutex探测,如果已经占用就广播消息通知第一个程序,然后第一个程序做出响应)
unit MultInst; interface const MI_QUERYWINDOWHANDLE = ; MI_RESPONDWINDOWHANDLE = ; MI_ERROR_NONE = ; ...
- jQuery_基础
一.jQuery与DOM对象的转换. 1.jQuery对象转换为DOM对象:$cr[0] 或 $cr.get(0) $cr为jQuery对象 2.DOM对象转换为jQuery对象:$(cr) cr为D ...