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;

相关文章
|
5月前
|
SQL 数据库 数据库管理
必知的技术知识:FMDB基本操作
必知的技术知识:FMDB基本操作
|
Dart Linux 开发工具
带你读《深入浅出Dart》一、搭建环境(附序)
带你读《深入浅出Dart》一、搭建环境(附序)
108 0
|
SQL 数据可视化 数据库
【SQLite预习课3】SQLite 的常用语法
【SQLite预习课3】SQLite 的常用语法
160 0
|
SQL 算法 中间件
sqlalchemy源码阅读-下篇
SQLAlchemy是Python SQL工具箱和ORM框架,它为应用程序开发人员提供了全面而灵活的SQL功能。它提供了一整套企业级持久化方案,旨在高效,高性能地访问数据库,并符合Pythonic之禅。项目代码量比较大,接近200个文件,7万行代码, 我们一起来挑战一下。
424 1
sqlalchemy源码阅读-下篇
|
SQL 安全 关系型数据库
SQLAlchemy源码阅读-上篇
SQLAlchemy是Python SQL工具箱和ORM框架,它为应用程序开发人员提供了全面而灵活的SQL功能。它提供了一整套企业级持久化方案,旨在高效,高性能地访问数据库,并符合简单的Pythonic哲学。项目代码量比较大,接近200个文件,7万行代码, 我们一起来挑战一下。 作者:游戏不存在 链接:https://juejin.cn/post/6951945198322581518 来源:稀土掘金 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
317 2
SQLAlchemy源码阅读-上篇
|
存储 关系型数据库 MySQL
干货|Sqlite数据库知识必知必会(下篇)
干货|Sqlite数据库知识必知必会(下篇)
255 0
干货|Sqlite数据库知识必知必会(下篇)
|
SQL 存储 NoSQL
SQLite学习之开篇
  一、简介:   SQLite是目前最流行的开源嵌入式数据库,和很多其他嵌入式存储引擎相比(NoSQL),如BerkeleyDB、MemBASE等,SQLite可以很好的支持关系型数据库所具备的一些基本特征,如标准SQL语法、事务、数据表和索引等。事实上,尽管SQLite拥有诸多关系型数据库的基本特征,然而由于应用场景的不同,它们之间并没有更多的可比性。下面我们将列举一下SQLite的主要特征:   1). 管理简单,甚至可以认为无需管理。   2). 操作方便,SQLite生成的数据库文件可以在各个平台无缝移植。   3). 可以非常方便的以多种形式嵌入到其他应用程序中,如静态库、
281 0
|
Java API Android开发
老司机用一篇博客带你快速熟悉Dart语法
版权声明:本文为博主原创文章,未经博主允许不得转载。https://www.jianshu.com/p/3d927a7bf020 转载请标明出处:https://www.jianshu.com/p/3d927a7bf020 本文出自 AWeiLoveAndroid的博客 【前言】Dart语言是使用flutter框架开发时候必备的语言,flutter是一个跨平台的框架,一套代码就可以完美实现安卓和ios两个平台,适配也很不错,Dart语言很友好,和java很类似,学习成本也是很低的。
2660 0
|
SQL 数据库 数据库管理
[UWP小白日记-2]SQLite数据库DOME
原文:[UWP小白日记-2]SQLite数据库DOME   数据库说简单点就是增删改查,但是对新手来说也是要爆肝的。作为一个新手爆肝无数次啊, 血的教训啊现在UWP的教程又少,说多了都是泪。留下来免得以后又爆肝。
1393 0