第三方数据库FMDB

•FMDB的使用:在sqlite的基础上,将sqlite中的函数进行封装产生的一个数据库文件。
–FMDB的好处是对基本C库的封装,方便使用。同时还提供了多线程操作数据库带来的读脏数据等问题的方法。
–FMDB有三个主要的类

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

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

FMDatabaseQueue:用于在多线程中执行多个查询或更新,它是线程安全的
 
 
对数据库所有的操作只需下面的方法即可:
查询语句:- (FMResultSet *)executeQuery:(NSString*)sql, ...    

- (BOOL)next;

                    -{type}ForColumnIndex:(int)columnIdx

创建、插入、修改等等语句:- (BOOL)executeUpdate:(NSString*)sql, ...
 

执行SQL语句:

<1>使用:(需要FMDatabase *db成员变量)
     创建或打开:FMDataBase类

self.db = [FMDatabase databaseWithPath:fileName];  //创建数据库

[self.db open];//打开数据库

[self.db close]; //关闭数据库

//对数据库进行插入、修改的操作

[self.db executeUpdate:@“CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT,age INTEGER)”];

[self.db executeUpdate:@"INSERT INTO t_student(name , age) VALUES(?, ?);", @"xuneng", @(10)];

[self.db executeUptate:@"update t_student set name = 'lisi' where age = @(10)"];

<2>查询:FMResultSet类(数据取出完全后,不需要再去关闭结果集,当新的结果集产生,或者其数据库关闭时,会自动关闭。)

// 1.查询

FMResultSet *set = [self.db  executeQuery:@"SELECT * FROM t_student;"];  //返回结果集

// 2.取出数据

while ([set next])

{

   // 取出姓名

NSString *name = [set stringForColumnIndex:1];

  // 取出年龄   

int age = [set intForColumnIndex:2];

NSString *name = [set stringForColumn:@"name"];

int age = [set intForColumn:@"age"];

NSLog(@"name = %@, age = %d", name, age);

}

创建数据库并进行增删改查的操作举例如下:

1、首先导入sqlite本地数据库和第三方数据库FMDB

2、在UIViewController类中对数据库表进行增删该查操作如下:

《1》数据库路径

NSArray *dics = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

NSString *dbPath = [[dics lastObject] stringByAppendingPathComponent:@"user.db"];

《2》 创建数据库

self.db = [FMDatabase databaseWithPath:dbPath];

《3》打开数据库

if(![self.db open])

{

return; //打开数据库失败

}

《4》创建数据库表

if(![self.db executeUpdate:@"create table if not exists user (ID integer primary key autoincrement,name text,password text)"])

{

return; //创建数据库表失败

}

《5》插入数据

if(![self.db executeUpdate:@"insert into user (name,password) values('admin','123456')"])

{

return; //插入数据失败

}

《6》修改数据

if(![self.db executeUpdate:@"update user set name = 'zhangsan' where ID = 2"])

{

return; //修改数据失败

}

  

《7》获取结果集

FMResultSet *resultSet = [self.db executeQuery:@"select * from user"];

《8》遍历结果集,取出数据

while ([resultSet next])

{

int ID = [resultSet intForColumnIndex:0];

NSString *name = [resultSet stringForColumnIndex:1];

NSString *password = [resultSet stringForColumnIndex:2];

NSLog(@"ID:%d,name:%@,password:%@",ID,name,password);

}

《8》//关闭数据库

[self.db close];

演示结果如下:

-- ::38.640 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:zhangsan,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:

iOS:第三方数据库文件FMDB的使用的更多相关文章

  1. iOS开发数据库篇—FMDB简单介绍

    iOS开发数据库篇—FMDB简单介绍 一.简单说明 1.什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 2.FMDB的优点 使用起来 ...

  2. iOS开发数据库篇—FMDB数据库队列

    iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: // // YYViewContr ...

  3. IOS第三方数据库--FMDB

    iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...

  4. IOS第三方数据库--FMDB 分类: ios技术 2015-03-01 09:38 57人阅读 评论(0) 收藏

    iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...

  5. iOS 把数据库文件打包到mainbundle中,查找不到路径的解决的方法;以及在删除bundle中文件的可行性

    在开发中有时我们须要把数据库文件打包到我们的项目中.一般我们都是在外部用工具生成数据库文件,然后拉入项目中.可是我们在程序中查找改文件时.返回的路径总是nil 解决的方法: 原因我们拉入其它资源文件( ...

  6. iOS开发数据库-FMDB

    前言 FMDB是以OC的方式封装了SQLite的C语言API,使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码:对比苹果自带的Core Data框架,更加轻量级和灵活:提供了多线程安全的数据库操 ...

  7. QF——iOS中的数据库操作:SQLite数据库,第三方封装库FMDB,CoreData

    SQLite数据库: SQLite是轻量级的数据库,适合应用在移动设备和小型设备上,它的优点是轻量,可移植性强.但它的缺点是它的API是用C写的,不是面向对象的.整体来说,操作起来比较麻烦.所以,一般 ...

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

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

  9. IOS数据存储之FMDB数据库

    前言: 最近几天一直在折腾数据库存储,之前文章(http://www.cnblogs.com/whoislcj/p/5485959.html)介绍了Sqlite 数据库,SQLite是一种小型的轻量级 ...

随机推荐

  1. MySQL5.7 centos7.2 yum 安装

    1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo/yum/  # 下载mysql源安装包 shell> wge ...

  2. SGU 204. Little Jumper

    204. Little Jumper time limit per test: 0.5 sec. memory limit per test: 65536 KB input: standard out ...

  3. [实战]MVC5+EF6+MySql企业网盘实战(22)——图片列表

    写在前面 实现逻辑是:单击图片节点,加载所有的当前用户之前上传的图片,分页,按时间倒序加载. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MyS ...

  4. js 利用事件委托解决mousedown中的click

    有一个需求是这样的: 父元素div绑定一个mousedown事件,子元素a绑定一个click事件. 看解构: <div id="nav"> <a href=&qu ...

  5. Python并发编程-一个简单的多进程实例

    import time from multiprocessing import Process import os def func(args,args2): #传递参数到进程 print(args, ...

  6. React Native 系列(二)

    前言 本系列是基于React Native版本号0.44.3写的,最初学习React Native的时候,完全没有接触过React和JS,本文的目的是为了给那些JS和React小白提供一个快速入门,让 ...

  7. 【BZOJ 2555】 2555: SubString (SAM+LCT)

    2555: SubString Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 2548  Solved: 762 Description 懒得写背景了 ...

  8. [SPOJ SEQN] [hdu3439]Sequence

    题目就是求C(n,k)*H(n - k)%m 0<= k<= n <=10^9, 1 <= m <= 10^5, n != 0 其中H(n)是错排第n项. 对于C(n,k ...

  9. [BZOJ4539][HNOI2016]树(主席树)

    4539: [Hnoi2016]树 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 746  Solved: 292[Submit][Status][D ...

  10. bzoj 2056: gift? 高精度?

    2056: gift? 高精度? Time Limit: 10 Sec  Memory Limit: 1 MB Description   Input 输入的第一行为一个整数t. 接下来t行,每行包含 ...