IOS开发-封装数据库sqlite3之为何选择FMDB

时间:2023-03-10 00:48:31
IOS开发-封装数据库sqlite3之为何选择FMDB

为什么使用第三方轻量级框架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封装也是这样。