n什么是FMDB

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

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

p nFMDB的优点

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

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

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

p nFMDB的github地址

phttps://github.com/ccgus/fmdb p

    1. 核心类

    2. nFMDB有三个主要的类

    3. pFMDatabase

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

    5. ü用来执行SQL语句

    6. ü pFMResultSet

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

    8. ü pFMDatabaseQueue

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

    10. 打开数据库

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

    12. FMDatabase *db = [FMDatabasedatabaseWithPath:path];

    13. if (![db open])

    14. {

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

    16. }

    17. n n文件路径有三种情况

    18. p具体文件路径

    19. ü如果不存在会自动创建

    20. ü p空字符串@""

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

    22. ü当FMDatabase连接关闭时,数据库文件也被删除

    23. p pnil

    24. ü会创建一个内存中临时数据库,当FMDatabase连接关闭时,数据库会被销毁

    25. 执行更新

    26. n在FMDB中,除查询以外的所有操作,都称为“更新”pcreate、drop、insert、update、delete等

    27. p n使用executeUpdate:方法执行更新

    28. p- (BOOL)executeUpdate:(NSString*)sql, ...

    29. p- (BOOL)executeUpdateWithFormat:(NSString*)format, ...

    30. p- (BOOL)executeUpdate:(NSString*)sqlwithArgumentsInArray:(NSArray *)arguments

    31. p n示例

    32. [db executeUpdate:@"UPDATE t_student SET age = ? WHERE name = ?;", @20, @"Jack"]

    33. 执行查询

    34. n查询方法

    35. p- (FMResultSet *)executeQuery:(NSString*)sql, ...

    36. p- (FMResultSet *)executeQueryWithFormat:(NSString*)format, ...

    37. p- (FMResultSet *)executeQuery:(NSString *)sqlwithArgumentsInArray:(NSArray *)arguments

    38. p n示例

    39. // 查询数据

    40. FMResultSet *rs = [db executeQuery:@"SELECT * FROMt_student"];

    41. // 遍历结果集

    42. while ([rs next])

    43. {

    44. NSString *name = [rs stringForColumn:@"name"];

    45. int age = [rs intForColumn:@"age"];

    46. double score = [rs doubleForColumn:@"score"];

    47. }

李洪强

在面试的时候,如果问数据库怎么搞得,不能只说FMDB

可以这样说:

我用SQLite,FMDB也会封装这些东西,也会做一些改变,所以最终用这个框架去实现

用终端下载第三方框架

在桌面新建文件夹gitHub

输入 cd  拖入新建文件夹  回车  输入 git clone 把在github里下载第三方框架的地址拷贝过来 回车

现在就是正在下载的状态了...

在xcode 新建项目导入新框架

在项目里导入FMDB的头文件

#import "FMDB.h"

定义一个全局的属性dataBase

@property(nonatomic,strong)FMDatabase *dataBase;

判断数据库是否打开成功

- (void)viewDidLoad {

[super viewDidLoad];

// 1 - 创建数据库

NSString *path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask, YES) lastObject]stringByAppendingPathComponent:@"student"];

FMDatabase *dataBase = [FMDatabasedatabaseWithPath:path];

self.dataBase = dataBase;

BOOL success = [dataBase open];

if (success) {

NSLog(@"数据库创建成功");

}else{

NSLog(@"数据库创建失败");

}

判断是否创建成功,只有创建成功才去执行第二步

2 - 创建表

执行 - 只要不是查询都用updata 更新

//2 - 创建表

NSString *str = @"CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT ,name TEXT NOT NULL ,score REAL NOT NULL)";

//执行

[self.dataBase executeUpdate:str];

}else{

NSLog(@"数据库创建失败");

}

做一个插入,一个查询,因为查询有代表性

- (IBAction)insertData:(UIButton *)sender {

//插入数据

for (int i = 0; i < 100; i ++) {

NSString *nameStr = [NSString stringWithFormat:@"周杰伦 - %d",i];

NSString *sqlStr = [NSStringstringWithFormat:@"INSERT INTO t_student (name,score)VALUES('%@',%.2f)",nameStr,arc4random_uniform(1000)/10.0];

//执行

BOOL success = [self.dataBase executeUpdate:sqlStr];

if (success) {

NSLog(@"添加成功");

}else{

NSLog(@"添加失败");

}

}

next方法

如果是YES,取到数据了

如果是NO 没有取到数据

如果取到,应该把两个数据拿出来

一个是name ,一个是score

用SQL和FMDB的使用的区别

线程安全

公共资源A使用的时候,B不能使用

一个公共的 值是100

A对公共的执行操作完成之前

B不能操作

在最新值的基础上再进行操作

操作之前连读取都不能

排队

A执行完成之后写到数据库,才是结束

枷锁

用FMDB加锁

新建一个项目: FMDB的线程安全

导入框架

一个是拖入框架,一个是导入系统的sql

1 - 指定沙盒路径

2 - 创建数据库队列

- (void)viewDidLoad {

[super viewDidLoad];

//指定沙盒路径

NSString *path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)lastObject]stringByAppendingPathComponent:@"data.sqlite"];

//创建数据库的队列

FMDatabaseQueue *dataBaseQ = [FMDatabaseQueuedatabaseQueueWithPath:path];

//线程安全

[dataBaseQ inDatabase:^(FMDatabase *db) {

BOOL success = [db open];

if (success) {

NSLog(@"创建库成功");

//2 - 创建数据库成功了,我才去创建表

NSString *str = @"CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT ,name TEXT NOT NULL ,score REAL NOT NULL)";

if ([db executeUpdate:str]) {

NSLog(@"创建表成功");

}else{

NSLog(@"创建表失败");

}

}else{

NSLog(@"创建库失败");

}

}];

}

接下来演示线程安全下的添加和查询数据

把创建的队列定义一个全局的属性

- (IBAction)insertData:(UIButton *)sender {

//线程安全下的增加数据

[self.dataBaseQ inDatabase:^(FMDatabase *db) {

for (int i = 0; i < 100; i ++) {

NSString *nameStr = [NSString stringWithFormat:@"周杰伦 - %d",i];

NSString *sqlStr = [NSStringstringWithFormat:@"INSERT INTO t_student (name,score)VALUES('%@,%.2f)",nameStr,arc4random_uniform(1000)/10.0];

BOOL success = [db executeUpdate:sqlStr];

if (success) {

NSLog(@"添加数据成功");

}else{

NSLog(@"添加数据失败");

}

}

}];

}

查询

李洪强iOS面试总结之- FMDB的更多相关文章

  1. 李洪强iOS经典面试题156 - Runtime详解(面试必备)

    李洪强iOS经典面试题156 - Runtime详解(面试必备)   一.runtime简介 RunTime简称运行时.OC就是运行时机制,也就是在运行时候的一些机制,其中最主要的是消息机制. 对于C ...

  2. 李洪强iOS经典面试题155 - const,static,extern详解(面试必备)

    李洪强iOS经典面试题155 - const,static,extern详解(面试必备) 一.const与宏的区别(面试题): const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽 ...

  3. 李洪强iOS经典面试题144-数据存储

    李洪强iOS经典面试题144-数据存储   数据存储 sqlite中插入特殊字符的方法和接收到处理方法. 除'其他的都是在特殊字符前面加"/",而 ' -> '' .方法:k ...

  4. 李洪强iOS经典面试题142-第三方框架及其管理

    李洪强iOS经典面试题142-第三方框架及其管理   第三方框架及其管理 使用过CocoaPods吗?它是什么?CocoaPods的原理? CocoaPod是一个第三方库的管理工具,用来管理项目中的第 ...

  5. 李洪强iOS经典面试题140-UI

    李洪强iOS经典面试题140-UI   UI viewcontroller的一些方法的说明viewDidLoad,viewWillDisappear, viewWillAppear方法的 顺序和作用? ...

  6. 李洪强iOS经典面试题下

    李洪强iOS经典面试题下 21. 下面的代码输出什么? @implementation Son : Father - (id)init { self = [super init]; if (self) ...

  7. 李洪强iOS经典面试题

    李洪强iOS经典面试题 1. struct和class的区别 swift中,class是引用类型,struct是值类型.值类型在传递和赋值时将进行复制,而引用类型则只会使用引用对象的一个"指 ...

  8. 李洪强iOS经典面试题34-求两个链表表示的数的和

    李洪强iOS经典面试题34-求两个链表表示的数的和 问题 给你两个链表,分别表示两个非负的整数.每个链表的节点表示一个整数位. 为了方便计算,整数的低位在链表头,例如:123 在链表中的表示方式是: ...

  9. 李洪强iOS开发之iOS学习方法收集

    李洪强iOS开发之iOS学习方法收集 在这里收集一些iOS学习方法,会不断更新 项目 简述 日期 一年多iOS开发总结 作者总结了自己一年多的iOS学习经验,对于iOS初学者来说很多地方是可以借鉴的 ...

随机推荐

  1. Linux rsync 同步

    rsync 是一个快速增量文件传输工具,它可以用于在同一主机备份内部的备分,我们还可以把它作为不同主机网络备份工具之用.本文主要讲述的是如何自架rsync服务器,以实现文件传输.备份和镜像.相对tar ...

  2. JSP的7个动作指令

    动作指令与编译指令不同,编译指令是通知Servlet引擎的处理信息,而动作指令知识运行时的动作.编译指令在将JSP编译成Servlet时起作用,而处理指令通常可替换成JSP脚本,它知识JSP脚本的标准 ...

  3. iOS 取得单张系统图片

    这里主要用到了UIImagePickerController 不多废话,直接上代码 // // RootViewController.m // GetImageFromPhotoAlbum // // ...

  4. JavaScript美术馆进化史

    内容选自<<JavaScript DOM 编程艺术>>第4-6章,跟着作者一起见证美术馆的进化吧. 先放效果图,然后一步步做出每个效果.每个效果都有它实用的地方,且知道过程可以 ...

  5. responsive menu

    http://responsive-nav.com/#instructions https://github.com/viljamis/responsive-nav.js http://tympanu ...

  6. Shade勒索病毒 中敲诈病毒解密 如 issbakev9_Data.MDF.id-A1E.f_tactics@aol.com.xtbl 解决方法

    [客户名称]:福建福州市某烘焙连锁企业 [软件名称]:思迅烘焙之星V9总部 [数据库版本]:MS SQL server 2000  [数据库大小]:4.94GB [问题描述]:由于客户服务器安全层薄弱 ...

  7. SQL中的5种聚集函数

    作为一个刚毕业进入这行的菜鸟,婶婶的觉的那种大神.大牛到底是怎样炼成的啊,我这小菜鸟感觉这TMD要学的东西这多啊,然后就给自己定了许多许多要学习的东西,可是有人又不停地给你灌输:东西不在多而要精通!我 ...

  8. 一些 Shell 脚本(持续更新)

    1. 启动日志分析 启动日志格式如下: 开机时间:2015/05/13 周三 16:45:17.79 关机时间:2015/05/13 周三 18:46:03.91 开机时间:2015/05/14 周四 ...

  9. [原创] zabbix学习之旅二:yum安装

    对于允许连接公网的环境下,显然通过yum安装是最为简单方便的,也是官网推荐的安装方式.通过这种方式安装,会将php.apache.zabbix本身都一并安装,解决了烦人的依赖包问题.   本文将介绍如 ...

  10. ubuntu mysql 使用

    环境:ubuntu 12.04.5    mysql-server-5.5 安装:sudo apt-get install mysql-server-5.5 (服务端 第一台虚拟机) sudo apt ...