FMDB的一些摘抄

简介: FMDB的一些摘抄

什么是FMDB

FMDB是iOS平台的SQLite数据库框架

FMDB以OC的方式封装了SQLite的C语言API

FMDB的优点

使用起来更加面向对象,省去了很多麻烦、冗余的C语言代码

提供了多线程安全的数据库操作方法,有效地防止数据混乱

FMDB的github地址

https://github.com/ccgus/fmdb

核心类

FMDB有三个主要的类

FMDatabase

一个FMDatabase对象就代表一个单独的SQLite数据库

用来执行SQL语句

FMResultSet

使用FMDatabase执行查询后的结果集

FMDatabaseQueue

用于在多线程中执行多个查询或更新,它是线程安全的

打开数据库

通过指定SQLite数据库文件路径来创建FMDatabase对象

FMDatabase*db = [FMDatabasedatabaseWithPath:path];

if(![dbopen]) {

NSLog(@"数据库打开失败!");

}

文件路径有三种情况

具体文件路径

如果不存在会自动创建

空字符串@""

会在临时目录创建一个空的数据库

当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

示例

[dbexecuteUpdate:@"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 = [dbexecuteQuery:@"SELECT * FROM t_student"];

遍历结果集

while([rsnext]) {

NSString*name = [rsstringForColumn:@"name"];

intage = [rsintForColumn:@"age"];

doublescore = [rsdoubleForColumn:@"score"];

}

FMDatabaseQueue

FMDatabase这个类是线程不安全的,如果在多个线程中同时使用一个FMDatabase实例,会造成数据混乱等问题

为了保证线程安全,FMDB提供方便快捷的FMDatabaseQueue类

FMDatabaseQueue的创建

FMDatabaseQueue*queue

= [FMDatabaseQueuedatabaseQueueWithPath:path];

FMDatabaseQueue

简单使用

[queueinDatabase:^(FMDatabase*db) {

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Jack"];

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Rose"];

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Jim"];

FMResultSet*rs = [dbexecuteQuery:@"select * from

t_student"];

while([rsnext]) {

// …

}

}];

FMDatabaseQueue

使用事务

[queueinTransaction:^(FMDatabase*db,BOOL*rollback) {

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Jack"];

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Rose"];

[dbexecuteUpdate:@"INSERT INTO

t_student(name) VALUES (?)",@"Jim"];

FMResultSet*rs = [dbexecuteQuery:@"select * from

t_student"];

while([rsnext]) {

// …

}

}];

事务回滚

*rollback =YES;

相关文章
|
10月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
984 4
|
传感器 Android开发 iOS开发
Flutter插件开发指南02: 事件订阅 EventChannel
上一节我们讲了 Channel 通道,但是如果你是卫星定位业务,原生端主动推消息给 Flutter 这时候就要用到 EventChannel 通道了。 本节会写一个 1~50 的计数器,到 50 后自动关闭原生的消息订阅。
307 1
Flutter插件开发指南02:  事件订阅 EventChannel
|
缓存 数据格式
实现LRU缓存的三种方式(建议收藏)
LRU全称为Least Recently Used,即最近使用的。针对的是在有限的内存空间内,只缓存最近使用的数据(即get和set的数据),超过有限内存空间的数据将会被删除。这个在面试题中也是常会被问到的内容,接下来就看看怎么来实现。
1991 0
实现LRU缓存的三种方式(建议收藏)
|
iOS开发
Flutter与iOS原生通信方式
Flutter与iOS原生通信方式
655 2
|
网络协议 算法 网络架构
计算机网络期末复习——基础知识汇总(二)
计算机网络期末复习——基础知识汇总(二)
190 0
给 element-plus 增加一个防抖的功能(二)
element-plus 功能非常强大,但是好像只有 el-autocomplete 提供了一个防抖功能,其他表单子控件并没有提供防抖功能,而 el-autocomplete 的防抖和我想要的效果又不太一样,所以只好写个函数实现我想要的防抖效果。
|
物联网 测试技术 Android开发
蓝牙BLE传输性能及延迟分析
BLE传输性能主要受以下几个因素影响:操作类型,Connection Interval,每个Connection Event内发送的帧数、每一帧数据的长度。具体参见如下链接: https://en.wikipedia.
4138 0
|
10月前
|
前端开发 JavaScript 安全
如何在 React Native 中实现热更新?
如何在 React Native 中实现热更新?
968 64
|
Web App开发 开发工具 Android开发
【Flutter】Flutter安装和配置(mac)
【Flutter】Flutter安装和配置(mac)