李洪强iOS面试总结之- 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(@"添加数据失败");
}
}
}];
}
查询
李洪强iOS面试总结之- FMDB的更多相关文章
- 李洪强iOS经典面试题156 - Runtime详解(面试必备)
李洪强iOS经典面试题156 - Runtime详解(面试必备) 一.runtime简介 RunTime简称运行时.OC就是运行时机制,也就是在运行时候的一些机制,其中最主要的是消息机制. 对于C ...
- 李洪强iOS经典面试题155 - const,static,extern详解(面试必备)
李洪强iOS经典面试题155 - const,static,extern详解(面试必备) 一.const与宏的区别(面试题): const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽 ...
- 李洪强iOS经典面试题144-数据存储
李洪强iOS经典面试题144-数据存储 数据存储 sqlite中插入特殊字符的方法和接收到处理方法. 除'其他的都是在特殊字符前面加"/",而 ' -> '' .方法:k ...
- 李洪强iOS经典面试题142-第三方框架及其管理
李洪强iOS经典面试题142-第三方框架及其管理 第三方框架及其管理 使用过CocoaPods吗?它是什么?CocoaPods的原理? CocoaPod是一个第三方库的管理工具,用来管理项目中的第 ...
- 李洪强iOS经典面试题140-UI
李洪强iOS经典面试题140-UI UI viewcontroller的一些方法的说明viewDidLoad,viewWillDisappear, viewWillAppear方法的 顺序和作用? ...
- 李洪强iOS经典面试题下
李洪强iOS经典面试题下 21. 下面的代码输出什么? @implementation Son : Father - (id)init { self = [super init]; if (self) ...
- 李洪强iOS经典面试题
李洪强iOS经典面试题 1. struct和class的区别 swift中,class是引用类型,struct是值类型.值类型在传递和赋值时将进行复制,而引用类型则只会使用引用对象的一个"指 ...
- 李洪强iOS经典面试题34-求两个链表表示的数的和
李洪强iOS经典面试题34-求两个链表表示的数的和 问题 给你两个链表,分别表示两个非负的整数.每个链表的节点表示一个整数位. 为了方便计算,整数的低位在链表头,例如:123 在链表中的表示方式是: ...
- 李洪强iOS开发之iOS学习方法收集
李洪强iOS开发之iOS学习方法收集 在这里收集一些iOS学习方法,会不断更新 项目 简述 日期 一年多iOS开发总结 作者总结了自己一年多的iOS学习经验,对于iOS初学者来说很多地方是可以借鉴的 ...
随机推荐
- (转)前端构建工具gulp入门教程
前端构建工具gulp入门教程 老婆婆 1.8k 2013年12月30日 发布 推荐 10 推荐 收藏 83 收藏,20k 浏览 本文假设你之前没有用过任何任务脚本(task runner)和命令行工具 ...
- WinForm GDI+自定义控件总结(一)
前言 由于项目的原因好久没写博客了,也正是项目的原因开始系统的学习WinForm,从而接触到自定义控件的开发.自定义控件的开发有一定的难度,对开发者要求比较高,需要了解Windows运行的机制,熟悉w ...
- asp.net mvc 错误路由默认配置
问题描述:默认情况下mvc已经将路由参数设置配置好了,这里就不在讲解,请到园子搜索,有很多这方面相关的文章.这里讲述的是,一个MVC项目中,我们输入一个错误的URL,或者根本不存在的URL,如:htt ...
- Mysql去除重复
常用的有两种方法,第一种就是select distinct name from table.但是有时候我们要返回多个字段时就用第二种方法select *, count(distinct name) f ...
- P2763: [JLOI2011]飞行路线
然而WA了呀,这道分层图,也是不明白为什么WA了=-= ; maxn=; points=; type node=record f,t,l:longint; end; var n,m,k,i,j,u,v ...
- c判断括弧是否匹配
这里我没有用堆栈.直接用一个数组input[SIZE]接收用户的输入,在遍历数组,对数组进行操作.已经匹配好的括弧直接用#号覆盖,最后遍历数组.如果数组只有#号,没有其他元素,则匹配.否则不匹配. / ...
- 在FreeBSD上搭建Mac的文件及time machine备份服务
上周将工作用电脑由公司配备的台式机切换到自己低配的macbook air上面,小本本的128G SSD远远不能满足工作的储存需要,但又不舍得入手昂贵的AirPort Time Capsule,于是考虑 ...
- 学习Linux第五天
1.VIM编辑器 3种模式: Command Model , Insert Model , Last line Model 安装vim: sudo apt-get install vim 如果提示出错 ...
- django构建blog--建立数据库部分+admin部分(eclipse+pydev)
本文介绍的是在eclipse+pydev 平台下,利用django 搭建blog的第1部分:建立数据库+admin部分 步骤一:创建myweb项目+blog应用 1. Eclipse下新建一个djan ...
- UVA 10078 The Art Gallery
Problem: Century Arts has hundreds of art galleries scattered all around the country and you are hir ...