为什么使用第三方轻量级框架FMDB?

FMDB是用于进行数据存储的第三方的框架,它与SQLite与Core Data相比较,存在很多优势。

FMDB是面向对象的,它以OC的方式封装了SQLite的C语言API,使用起来更加的方便,不需要过多的关心数据库操作的知识。

为什么不使用core data和SQLite?

Core Data是ORM的一种体现,实现了界面化操作。使用Core Data需要用到模型数据的转化,虽然操作简单,不需要直接操作数据库,但是性能没有直接使用SQLite高。但是SQLite使用的时候需要使用c语言中的函数,操作麻烦,因此需要对它进行封装。但是如果只是简单地封装,很可能会忽略很多重要的细节,比如如何处理并发以及安全性更问题。

下面简单封装sqlite来理解FMDB为什么那么好用呢?

新建SqleiteManage类实现封装:

 #import "SqleiteManage.h"
static SqleiteManage *manage = nil;
@implementation SqleiteManage //单例保证是同一个数据库
+(instancetype)shareManage{
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
manage = [[SqleiteManage alloc]init]; }); return manage;
} //打开数据库
-(int)openDB:(NSString *)str{
//1.打开数据库 建表
NSString *dbpath =[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:str];
NSLog(@"%@",dbpath); //打开数据库
result = sqlite3_open([dbpath UTF8String], &db);
if (SQLITE_OK ==result) {
NSLog(@"打开成功");
}else{
NSLog(@"打开失败");
} return result; } //关闭数据库
-(int)closeDB{
return sqlite3_close(db);
}
//------建表
-(BOOL)creatTableWithSqlite:(NSString *)sql{ if (result ==SQLITE_OK) { // 建表的SQL语句
// primary key autoincrement 定义 id为主键 值是自动增长的
// not null unique 不能为空 不能重复
// 建表的公式
// create table 表名 (字段名 字段的数据类型,字段名 字段的数据类型........);
// NSString *sql =@"create table if not exists user (id integer primary key autoincrement, name text not null unique, phone text, creatDate text);";
char *error;
int resul = sqlite3_exec(db, [sql UTF8String], NULL, NULL, &error);
[self closeDB];
if (resul == SQLITE_OK) { NSLog(@"建表成功");
return YES;
// return 跳出整个函数
// black 是跳出括号 }else{
NSLog(@"%s",error);
return NO;
} }
return NO;
} //插入
-(BOOL)insertMessageWithSql:(NSString *)sql{
if (result == SQLITE_OK) {
char *error;
int resul = sqlite3_exec(db, [sql UTF8String], NULL, NULL, &error);
[self closeDB];
if (resul == SQLITE_OK) {
return YES;
}else{
return NO;
} } return NO; } //删除
-(BOOL)deleteMessageWithSql:(NSString *)sql{
if (result == SQLITE_OK) {
char *error;
int resul = sqlite3_exec(db, [sql UTF8String], NULL, NULL, &error);
[self closeDB];
if (resul == SQLITE_OK) {
return YES;
}else{
return NO;
} }
return NO;
} //修改
-(BOOL)modifyMessageWithSql:(NSString *)sql{
if (result == SQLITE_OK) {
char *error;
int resul = sqlite3_exec(db, [sql UTF8String], NULL, NULL, &error);
[self closeDB];
if (resul == SQLITE_OK) {
return YES;
}else{
return NO;
} } return NO;
} -(NSArray*)queryMessageWithSQL:(NSString *)sql andObject:(NSString *)obj{
if (result==SQLITE_OK) {
// 声明一个结果集 查询的结果存放在结果集里面
sqlite3_stmt *stmt;
// 校验SQL语句是否正确 int nByte 为-1的时候 不限制 查询的长度
if (sqlite3_prepare_v2(db, [sql UTF8String], -, &stmt, NULL)==SQLITE_OK) {
// like 模糊查询 NSString *searchContent =[NSString stringWithFormat:@"%%%@%%",obj];
// 绑定要查询的内容
if ( sqlite3_bind_text(stmt, , [searchContent UTF8String], -, NULL)==SQLITE_OK
) {
NSMutableArray * resultlist = [NSMutableArray array];
// 循环 查询
while ( sqlite3_step(stmt)== SQLITE_ROW) {
// 把查询到的一条数据 整合到一个字典里面 // 1 是 icol 查询到的这一条数据的列数
char *name =(char *) sqlite3_column_text(stmt, );
char *phone = (char *) sqlite3_column_text(stmt, );
char *time =(char *) sqlite3_column_text(stmt, );
NSDictionary *info =@{@"name":[NSString stringWithUTF8String:name],@"phone":[NSString stringWithUTF8String:phone],@"time":[NSString stringWithUTF8String:time],};
[resultlist addObject:info];
}
[self closeDB];
return resultlist; }
} }
return nil;
}
@end

封装后使用:

#import "ViewController.h"
#import "SqleiteManage.h"
@interface ViewController () //数据库(Database):按照数据结构来组织、存储和管理数据
//数据库基本是由表,关系,操作构成
//在移动平台开发常用的是SQLite
//以表(table)为单位
//表头的每一列 都是一个字段(clumn,属性)
//可以通过字段查找到对应的数据
//ios 使用C语言操作数据库
//***** 使用数据库之前的先添加;ibsqlite3框架#import<> @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad];
//************数据库相关概念***************
/*
ios使用数据库的重要方法
打开数据库:sqlite3_open()
建表 修改 添加 更新 删除数据:sqlite3_exec()
查询:1.效验语句是否合法:sqlite3_prepare_v2
2.绑定要查询的数据和sql语句:sqlite3_bind_text
3.循环查找内容(根据行):sqlite3_step
4.取出这一行里面的数据(根据对应的类型):sqlite3_column_text
关闭数据库:sqlite3_close() SQL(Strured Query Language)是一种结构查询语言
SQL 语言特点:每一句后面都有一个;号结束 不区分大小写
SQL 的关键字:create update delete from where by table 。。。
在数据库里面不可以使用关键字来命名表名 或字段
数据库中的字符串 要用单引号 '' 括起来
sqlite 是关系型数据库 SQL语句使用公式
1.建表
@" create table (字段名 字段类型,字段名,字段类型);"
2.create table if not exists 表名(字段名,字段类型,)
如 :@"create table if not exists user(id integer,name text,phone text)
插入:insert into 表名(字段,字段)vlaus('内容','内容')
删除:delete from 表名 where 字段= '要删除的内容' 修改数据 :update 表名 set 字段 = '修改后的内容' where 字段 = '修改前的内容';
查询:
(1)select *from 表名 查询所有的字段(*表示所有);
(2)sele 字段1,字段2,......from 表名; 数据库的使用公式:
导入框架
1.创建数据库 打开数据库
2.创建表
3.添加 删除 修改 查询 内容 关闭数据库
//***********************************************************
*/
SqleiteManage * manage =[SqleiteManage shareManage];
// 打开数据库
[manage openDB:@"shujuku..sqlite"]; BOOL seccess = [manage creatTableWithSqlite: @"create table if not exists user (id integer primary key autoincrement, name text not null unique, phone text, creatDate text);"];
if (seccess) {
NSLog(@"建表成功");
}
// 插入数据公式
// insert into 表名 (字段,字段,字段) values ('','','');
NSString *name = @"小啊";
NSString * tel = @"";
NSString * date = @"2088-12-25"; // 插入数据
NSString *sql = [NSString stringWithFormat:@"insert into user (name, phone,creatDate) values ('%@','%@','%@');", name,tel,date ];
if ([manage insertMessageWithSql:sql]==YES) {
NSLog(@"插入数据成功");
} // 删除数据
if ([manage deleteMessageWithSql:@"delete from user where name= '小明';"]==YES) {
NSLog(@"删除数据成功");
}
if ([manage modifyMessageWithSql:@"update user set name = '大黄人' where name = '白马王子';"]==YES) {
NSLog(@"修改数据成功");
}
// 查询数据
NSArray * list = [manage queryMessageWithSQL:@"select id,name,phone,creatDate from user where name like ?;" andObject:@"小"];
if (list.count !=) {
NSLog(@"%@",list);
}
} - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
} @end

封装后sqlite,减少了很多代码,所有使用FMDB会非常好用。而且处理了多线程并发的问题。FMDB封装也是这样。

IOS开发-封装数据库sqlite3之为何选择FMDB的更多相关文章

  1. IOS开发——使用数据库

    IOS开发——使用FMDB数据库 简介 需求作用: 如果需要保存大量的结构较为复杂的数据的时候,使用数据库,例如交规考试项目 1.数据库的基本介绍 数据库(DB)是一种数据模型组织起来并存放存储管理的 ...

  2. iOS开发-Realm数据库

    Realm Realm-Object-c,见:https://realm.io/cn/docs/objc/latest/Realm官网:https://realm.io 使用流程 导入头文件#impo ...

  3. iphone/iOS 访问本地数据库sqlite3

    Phone也支持访问本地数据库Sqlite 3.这里简单的介绍一下iPhone上Sqlite 3的使用方法. 首先需要在项目中引用Sqlite 3的开发包,下面是在iPhone SDK 3.0下的目录 ...

  4. ios开发——实用技术篇Swift篇&照片选择

    照片选择 // MARK: - 选择照片 /*----- 选择照片 ------*/ @IBAction func addImageButtonClick() { let actionSheet = ...

  5. IOS学习笔记28—SQLite3第三方库之FMDB

    本文转载至 http://blog.csdn.net/happyrabbit456/article/details/11609451 SQLite是一种小型的轻量级的关系型数据库,在移动设备上使用是非 ...

  6. iOS开发使用半透明模糊效果方法整理

    虽然iOS很早就支持使用模糊效果对图片等进行处理,但尤其在iOS7以后,半透明模糊效果得到大范围广泛使用.包括今年最新发布的iOS8也沿袭了这一设计,甚至在OS X 10.10版Yosemite中也开 ...

  7. [转]iOS开发使用半透明模糊效果方法整理

    转自:http://www.molotang.com/articles/1921.html 虽然iOS很早就支持使用模糊效果对图片等进行处理,但尤其在iOS7以后,半透明模糊效果得到大范围广泛使用.包 ...

  8. iOS开发中的4种数据持久化方式【二、数据库 SQLite3、Core Data 的运用】

                   在上文,我们介绍了ios开发中的其中2种数据持久化方式:属性列表.归档解档.本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运 ...

  9. iOS开发数据库篇—SQLite简单介绍

    iOS开发数据库篇—SQLite简单介绍 一.离线缓存 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等. 说明:离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式 (1 ...

随机推荐

  1. 0020 Linux 文件操作命令

    1. 创建文件 touch 文件名 2. 删除文件 rm 文件名 3. 复制文件 cp 源文件 目录 4.剪切文件 mv 源文件 目标文件 5.重命名文件 mv 源文件名 新文件名 6.改变文件权限 ...

  2. linux split (分割文件)命令

    linux split 命令 功能说明:切割文件. 语 法:split [--help][--version][-<行数>][-b <字节>][-C <字节>][- ...

  3. github文件上传及github pages博客搭建教程

    一.与github建立连接 1.安装node.js和git 2.桌面新建文件夹[github],右键“git bash here” 3.注册github账号,新建仓库“new repository”, ...

  4. sqlserver中创建包含事务的存储过程

    什么是事务     事务时包含1条或多条语句的逻辑单元.事务中的语句是一个整体,要么一起提交,要么一起撤销.事务在提交前可以回滚,一旦提交就不能撤销修改了,是永久性的修改.   为什么使用事务     ...

  5. bzoj 3122: [Sdoi2013]随机数生成器

    #include<cstdio> #include<iostream> #include<map> #include<cmath> #define ll ...

  6. Codeforces Round #380 (Div. 2) 解题报告

    第一次全程参加的CF比赛(虽然过了D题之后就开始干别的去了),人生第一次codeforces上分--(或许之前的比赛如果都参加全程也不会那么惨吧),终于回到了specialist的行列,感动~.虽然最 ...

  7. css布局之两列布局

    我们见过两列布局的网站也很多,不过这种两列布局的分为两种:自适应和固定宽度 1.自适应两列布局 <!DOCTYPE html> <html lang="en"&g ...

  8. loadrunner (一)如何查看分析、报告结果

  9. 如何修改WAMP中mysql默认空密码 以及修改时报错的处理方法

    WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作. 首先,通过WAMP打开mysql控制台. 提示输入密码,因为现在是空,所以直接按回车 ...

  10. JS中数据类型及原生对象简介

    js是一种专门设计用来给网页增加交互性的编程语言,它的技术体系包含了一下几个方面: 1.JavaScript核心语言定义:包括数据类型,变量,常量,运算符,语句等. 2.原生对象和内置对象 3.浏览器 ...