李洪强经典面试题31- FMDB
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
核心类
nFMDB有三个主要的类
pFMDatabase
ü一个FMDatabase对象就代表一个单独的SQLite数据库
ü用来执行SQL语句
ü pFMResultSet
ü使用FMDatabase执行查询后的结果集
ü pFMDatabaseQueue
ü用于在多线程中执行多个查询或更新,它是线程安全的
打开数据库
n通过指定SQLite数据库文件路径来创建FMDatabase对象
FMDatabase *db = [FMDatabasedatabaseWithPath:path];
if (![db open])
{
NSLog(@"数据库打开失败!");
}
n n文件路径有三种情况
p具体文件路径
ü如果不存在会自动创建
ü p空字符串@""
ü会在临时目录创建一个空的数据库
ü当FMDatabase连接关闭时,数据库文件也被删除
p pnil
ü会创建一个内存中临时数据库,当FMDatabase连接关闭时,数据库会被销毁
执行更新
n在FMDB中,除查询以外的所有操作,都称为“更新”pcreate、drop、insert、update、delete等
p n使用executeUpdate:方法执行更新
p- (BOOL)executeUpdate:(NSString*)sql, ...
p- (BOOL)executeUpdateWithFormat:(NSString*)format, ...
p- (BOOL)executeUpdate:(NSString*)sqlwithArgumentsInArray:(NSArray *)arguments
p n示例
[db executeUpdate:@"UPDATE t_student SET age = ? WHERE name = ?;", @20, @"Jack"]
执行查询
n查询方法
p- (FMResultSet *)executeQuery:(NSString*)sql, ...
p- (FMResultSet *)executeQueryWithFormat:(NSString*)format, ...
p- (FMResultSet *)executeQuery:(NSString *)sqlwithArgumentsInArray:(NSArray *)arguments
p n示例
// 查询数据
FMResultSet *rs = [db executeQuery:@"SELECT * FROMt_student"];
// 遍历结果集
while ([rs next])
{
NSString *name = [rs stringForColumn:@"name"];
int age = [rs intForColumn:@"age"];
double score = [rs doubleForColumn:@"score"];
}
李洪强

在面试的时候,如果问数据库怎么搞得,不能只说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(@"添加数据失败");
}
}
}];
}
查询
李洪强经典面试题31- FMDB的更多相关文章
- 李洪强经典面试题49-Objective-C
李洪强经典面试题49-Objective-C 面试笔试都是必考语法知识的.请认真复习和深入研究OC. Objective-C 方法和选择器有何不同?(Difference between method ...
- 李洪强经典面试题152-Runtime
李洪强经典面试题152-Runtime Runtime Runtime是什么 Runtime 又叫运行时,是一套底层的 C 语言 API,其为 iOS 内部的核心之一,我们平时编写的 OC 代码, ...
- 李洪强经典面试题145-Runloop
李洪强经典面试题145-Runloop Runloop 什么是 Runloop? 从字面上讲就是运行循环. 它内部就是do-while循环,在这个循环内部不断地处理各种任务. 一个线程对应一个Ru ...
- 李洪强经典面试题136-KVO-KVC
李洪强经典面试题136-KVO-KVC KVC-KVO KVC的底层实现? 当一个对象调用setValue方法时,方法内部会做以下操作: ①检查是否存在相应key的set方法,如果存在,就调用se ...
- 李洪强经典面试题53-Swift
李洪强经典面试题53-Swift Swift 网上有很多Swift的语法题,但是Swift现在语法还未稳定,所以在这里暂时不贴出语法题,可以自行搜索. Swift和Objective-C的联系 Swi ...
- 李洪强经典面试题52-Block
李洪强经典面试题52-Block Block Block底层原理实现 首先我们来看四个函数 void test1() { int a = 10; void (^block)() = ^{ NSLo ...
- 李洪强经典面试题51-KVO-KVC
李洪强经典面试题51-KVO-KVC KVC-KVO KVC的底层实现? 当一个对象调用setValue方法时,方法内部会做以下操作: ①检查是否存在相应key的set方法,如果存在,就调用set ...
- 李洪强经典面试题48-C语言
可能碰到的iOS笔试面试题(4)--C语言 C语言,开发的基础功底,iOS很多高级应用都要和C语言打交道,所以,C语言在iOS开发中的重要性,你懂的.里面的一些问题可能并不是C语言问题,但是属于计 ...
- 李洪强经典面试题47--UNIX常用命令
可能碰到的iOS笔试面试题(3)--UNIX常用命令 做开发说用不到命令行,那肯定是不可能的.所以记住几个常用的命令还是很有用. cd 改变工作目录 pwd 输出当前工作目录的绝对路径在UNIX中要执 ...
随机推荐
- 全3D模具设计自动化解決方案
- Eclipse 编译java文件后出错 左树无红叉
问题描述: 今天遇见让人郁闷的问题,在项目工程中java文件编译通不过,eclipse在java文件中标示错误,但是却不不能在navigator的视图中像平常一样出现小红叉.通过clean proje ...
- javascript按钮点击事件问题
今天弄了个小测试,结果发现了点问题. 就是有一个按钮的点击事件,页面加载时候没反应,只有F12启用开发人员工具的时候才有反应.后来反复测试发现名字起的不太合理 function onclick(){ ...
- intellij idea console 乱码
修改文件 位置:{用户目录}\{iedea对应版本}\{idea or idea64}.vmoptions 比如我要修改我的配置文件 C:\Users\kkblf\.IntelliJIdea2017. ...
- Django之auth登录认证
前言:我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Django作为一个完美主义者的 ...
- CAD使用SetxDataDouble写数据(网页版)
主要用到函数说明: MxDrawEntity::SetxDataDouble 写一个Double扩展数据,详细说明如下: 参数 说明 [in] BSTR val 字符串值 szAppName 扩展数据 ...
- Spring框架系列(七)--Spring常用注解
Spring部分: 1.声明bean的注解: @Component:组件,没有明确的角色 @Service:在业务逻辑层使用(service层) @Repository:在数据访问层使用(dao层) ...
- 一天搞定jQuery(三)——使用jQuery完成复选框的全选和全不选
还记得之前我使用JavaScript来实现复选框的全选和全不选效果吗?如果读者初次翻阅本文,可记得看看教你一天玩转JavaScript(七)——使用JavaScript完成复选框的全选和全不选的效果! ...
- C# Task详解
1.Task的优势 ThreadPool相比Thread来说具备了很多优势,但是ThreadPool却又存在一些使用上的不方便.比如: ◆ ThreadPool不支持线程的取消.完成.失败通知等交互性 ...
- 51nod 1083 矩阵取数问题【动态规划】
一个N*N矩阵中有不同的正整数,经过这个格子,就能获得相应价值的奖励,从左上走到右下,只能向下向右走,求能够获得的最大价值. 例如:3 * 3的方格. 1 3 3 2 1 3 2 2 1 能够获得的最 ...