美文网首页
FMDB初体验

FMDB初体验

作者: 飞行的猫 | 来源:发表于2016-08-26 10:24 被阅读0次

什么是FMDB

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

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

●FMDB的优点

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

●对比苹果自带的Core Data框架,更加轻量级和灵活

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

●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];

●简单使用

[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]) {

// ...

}

}];

●使用事务

[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;

相关文章

  • FMDB初体验

    什么是FMDB ●FMDB是iOS平台的SQLite数据库框架 ●FMDB以OC的方式封装了SQLite的C语言A...

  • iOS-FMDB详解及使用

    一 FMDB简介 什么是 FMDB FMDB 是 iOS 平台的 SQLite 数据库框架 FMDB 以 OC 的...

  • iOS开发·FMDB的使用与知识梳理

    一、FMDB的介绍二、FMDB的使用说明三、FMDB的创建和使用方法 一、FMDB的介绍 FMDB是构建在SQLi...

  • FFDB

    FMDB的使用 FMDBDemo 目录 1、FMDB介绍2、FMDB导入3、FMDB框架中重要的框架类3.1、FM...

  • iOS数据持久化——FMDB(对SQLite的轻量级封装)

    一、FMDB简介 FMDB是一种第三方的开源库(ccgus/fmdb · GitHub),FMDB就是对SQLit...

  • SQLite数据库框架--FMDB

    FMDB概述 什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite...

  • Swift(FMDB的简单使用)

    一、FMDB的简单介绍 1.1、FMDB 的概念FMDB是iOS平台的SQLite数据库框架FMDB以OC的方式封...

  • FMDB的简述和简单使用

    一、FMDB的概念 1.什么是FMDB? (1)FMDB是iOS平台的SQLite数据库框架 (2)FMDB以OC...

  • Swift中使用FMDB IOS

    18-(掌握)FMDB基本使用 什么是FMDB?FMDB是iOS平台的SQLite数据库框架FMDB以OC的方式封...

  • FMDB常用操作

    FMDB 使用框架 官网地址 https://github.com/ccgus/fmdb 直接拖拽 将 fmdb ...

网友评论

      本文标题:FMDB初体验

      本文链接:https://www.haomeiwen.com/subject/tuzasttx.html