IOS开发:FMDB数据存储解析
IOS开发:FMDB数据存储解析
发布时间:2016-02-25 来源:查字典编辑
摘要:FMDB是面向对象的,它以OC的方式封装了SQLite的C语言API,使用起来更加的方便,不需要过多的关心数据库操作的知识。但是它本身也存在...

FMDB是面向对象的,它以OC的方式封装了SQLite的C语言API,使用起来更加的方便,不需要过多的关心数据库操作的知识。但是它本身也存在一些问题,比如跨平台,因为它是用oc的语言封装的,所以只能在ios开发的时候使用,如果想实现跨平台的操作,来降低开发的成本和维护的成本,就需要使用比较原始的SQLite。

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

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

因此,在这里推荐使用第三方框架FMDB,它是对libsqlite3框架的封装,用起来的步骤与SQLite使用类似,并且它对于多线程的同时操作一个表格时进行了处理,也就意味着它是线程安全的。FMDB是轻量级的框架,使用灵活,它是很多企业开发的首选。

FMDB中重要的类

FMDatabase:一个FMDatabase对象就代表一个单独的SQLite数据库,用来执行SQL语句

FMResultSet:使用FMDatabase执行查询后的结果集

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

IOS开发:FMDB数据存储解析1FMDB使用步骤

1. 下载FMDB文件 fmdb下载地址 ,将FMDB文件夹添加到项目中

2. 导入sqlite框架,导入FMDatabase.h文件

3.与SQLite使用步骤类似,需要获取数据库文件路径,然后获得数据库,并打开数据库,然后数据库进行操作,最后关闭数据库。代码如下所示:

// ViewController.m

// JRFMDB

//

// Created by jerehedu on 15/6/18.

// Copyright (c) 2015年 jerehedu. All rights reserved.

//

#import "ViewController.h"

#import "FMDatabase.h"

@interface ViewController ()

@property (nonatomic, strong) FMDatabase *db;

@end

@implementation ViewController

- (void)viewDidLoad

{

[super viewDidLoad];

//导入sqlite框架,导入FMDB文件夹

//1.获得数据库文件的路径

NSString *doc=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];

NSString *fileName=[doc stringByAppendingPathComponent:@"student.sqlite"];

NSLog(@"fileName = %@",fileName);

//2.获得数据库

FMDatabase *db = [FMDatabase databaseWithPath:fileName];

//3.打开数据库

if ([db open]) {

NSLog(@"ok");

//4.创表

BOOL result=[db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_student (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, age integer NOT NULL);"];

if (result) {

NSLog(@"创表成功");

}else{

NSLog(@"创表失败");

}

}

self.db=db;

//插入数据

[self insertStu];

[self deleteStu:6];

[self updateStu:@"apple7_name" :@"7777"];

[self queryStu];

[self dropStu];

[self insertStu];

[self queryStu];

//6.关闭数据库

[self.db close];

}

#pragma mark 插入数据

-(void)insertStu

{

for (int i=0; i

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新IOS开发学习
热门IOS开发学习
编程开发子分类