IOS第三方数据库--FMDB

iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便。于是,就出现了一系列将SQLite API进行封装的库,例如FMDB、PlausibleDatabase、sqlitepersistentobjects等,FMDB (https://github.com/ccgus/fmdb) 是一款简洁、易用的封装库,这一篇文章简单介绍下FMDB的使用。

在FMDB下载文件后,工程中必须导入如下文件,并使用 libsqlite3.dylib 依赖包。

FMDB同时兼容ARC和非ARC工程,会自动根据工程配置来调整相关的内存管理代码。

FMDB常用类:

FMDatabase : 一个单一的SQLite数据库,用于执行SQL语句。
FMResultSet :执行查询一个FMDatabase结果集,这个和android的Cursor类似。
FMDatabaseQueue :在多个线程来执行查询和更新时会使用这个类。

创建数据库:

[cpp] view plaincopyprint?

  1. db = [FMDatabase databaseWithPath:database_path];

1、当数据库文件不存在时,fmdb会自己创建一个。

2、 如果你传入的参数是空串:@"" ,则fmdb会在临时文件目录下创建这个数据库,数据库断开连接时,数据库文件被删除。

3、如果你传入的参数是 NULL,则它会建立一个在内存中的数据库,数据库断开连接时,数据库文件被删除。

打开数据库:

[cpp] view plaincopyprint?

  1. [db open]

返回BOOL型。

关闭数据库:

[cpp] view plaincopyprint?

  1. [db close]

数据库增删改等操作:

除了查询操作,FMDB数据库操作都执行executeUpdate方法,这个方法返回BOOL型。

看一下例子:

创建表:

[cpp] view plaincopyprint?

  1. if ([db open]) {
  2. NSString *sqlCreateTable =  [NSString stringWithFormat:@"CREATE TABLE IF NOT EXISTS ‘%@‘ (‘%@‘ INTEGER PRIMARY KEY AUTOINCREMENT, ‘%@‘ TEXT, ‘%@‘ INTEGER, ‘%@‘ TEXT)",TABLENAME,ID,NAME,AGE,ADDRESS];
  3. BOOL res = [db executeUpdate:sqlCreateTable];
  4. if (!res) {
  5. NSLog(@"error when creating db table");
  6. } else {
  7. NSLog(@"success to creating db table");
  8. }
  9. [db close];
  10. }

添加数据:

[cpp] view plaincopyprint?

  1. if ([db open]) {
  2. NSString *insertSql1= [NSString stringWithFormat:
  3. @"INSERT INTO ‘%@‘ (‘%@‘, ‘%@‘, ‘%@‘) VALUES (‘%@‘, ‘%@‘, ‘%@‘)",
  4. TABLENAME, NAME, AGE, ADDRESS, @"张三", @"13", @"济南"];
  5. BOOL res = [db executeUpdate:insertSql1];
  6. NSString *insertSql2 = [NSString stringWithFormat:
  7. @"INSERT INTO ‘%@‘ (‘%@‘, ‘%@‘, ‘%@‘) VALUES (‘%@‘, ‘%@‘, ‘%@‘)",
  8. TABLENAME, NAME, AGE, ADDRESS, @"李四", @"12", @"济南"];
  9. BOOL res2 = [db executeUpdate:insertSql2];
  10. if (!res) {
  11. NSLog(@"error when insert db table");
  12. } else {
  13. NSLog(@"success to insert db table");
  14. }
  15. [db close];
  16. }

修改数据:

[cpp] view plaincopyprint?

  1. if ([db open]) {
  2. NSString *updateSql = [NSString stringWithFormat:
  3. @"UPDATE ‘%@‘ SET ‘%@‘ = ‘%@‘ WHERE ‘%@‘ = ‘%@‘",
  4. TABLENAME,   AGE,  @"15" ,AGE,  @"13"];
  5. BOOL res = [db executeUpdate:updateSql];
  6. if (!res) {
  7. NSLog(@"error when update db table");
  8. } else {
  9. NSLog(@"success to update db table");
  10. }
  11. [db close];
  12. }

删除数据:

[cpp] view plaincopyprint?

  1. if ([db open]) {
  2. NSString *deleteSql = [NSString stringWithFormat:
  3. @"delete from %@ where %@ = ‘%@‘",
  4. TABLENAME, NAME, @"张三"];
  5. BOOL res = [db executeUpdate:deleteSql];
  6. if (!res) {
  7. NSLog(@"error when delete db table");
  8. } else {
  9. NSLog(@"success to delete db table");
  10. }
  11. [db close];
  12. }

数据库查询操作:

查询操作使用了executeQuery,并涉及到FMResultSet。

[cpp] view plaincopyprint?

  1. if ([db open]) {
  2. NSString * sql = [NSString stringWithFormat:
  3. @"SELECT * FROM %@",TABLENAME];
  4. FMResultSet * rs = [db executeQuery:sql];
  5. while ([rs next]) {
  6. int Id = [rs intForColumn:ID];
  7. NSString * name = [rs stringForColumn:NAME];
  8. NSString * age = [rs stringForColumn:AGE];
  9. NSString * address = [rs stringForColumn:ADDRESS];
  10. NSLog(@"id = %d, name = %@, age = %@  address = %@", Id, name, age, address);
  11. }
  12. [db close];
  13. }

FMDB的FMResultSet提供了多个方法来获取不同类型的数据:

数据库多线程操作:

如果应用中使用了多线程操作数据库,那么就需要使用FMDatabaseQueue来保证线程安全了。 应用中不可在多个线程中共同使用一个FMDatabase对象操作数据库,这样会引起数据库数据混乱。 为了多线程操作数据库安全,FMDB使用了FMDatabaseQueue,使用FMDatabaseQueue很简单,首先用一个数据库文件地址来初使化FMDatabaseQueue,然后就可以将一个闭包(block)传入inDatabase方法中。 在闭包中操作数据库,而不直接参与FMDatabase的管理。

[cpp] view plaincopyprint?

    1. FMDatabaseQueue * queue = [FMDatabaseQueue databaseQueueWithPath:database_path];
    2. dispatch_queue_t q1 = dispatch_queue_create("queue1", NULL);
    3. dispatch_queue_t q2 = dispatch_queue_create("queue2", NULL);
    4. dispatch_async(q1, ^{
    5. for (int i = 0; i < 50; ++i) {
    6. [queue inDatabase:^(FMDatabase *db2) {
    7. NSString *insertSql1= [NSString stringWithFormat:
    8. @"INSERT INTO ‘%@‘ (‘%@‘, ‘%@‘, ‘%@‘) VALUES (?, ?, ?)",
    9. TABLENAME, NAME, AGE, ADDRESS];
    10. NSString * name = [NSString stringWithFormat:@"jack %d", i];
    11. NSString * age = [NSString stringWithFormat:@"%d", 10+i];
    12. BOOL res = [db2 executeUpdate:insertSql1, name, age,@"济南"];
    13. if (!res) {
    14. NSLog(@"error to inster data: %@", name);
    15. } else {
    16. NSLog(@"succ to inster data: %@", name);
    17. }
    18. }];
    19. }
    20. });
    21. dispatch_async(q2, ^{
    22. for (int i = 0; i < 50; ++i) {
    23. [queue inDatabase:^(FMDatabase *db2) {
    24. NSString *insertSql2= [NSString stringWithFormat:
    25. @"INSERT INTO ‘%@‘ (‘%@‘, ‘%@‘, ‘%@‘) VALUES (?, ?, ?)",
    26. TABLENAME, NAME, AGE, ADDRESS];
    27. NSString * name = [NSString stringWithFormat:@"lilei %d", i];
    28. NSString * age = [NSString stringWithFormat:@"%d", 10+i];
    29. BOOL res = [db2 executeUpdate:insertSql2, name, age,@"北京"];
    30. if (!res) {
    31. NSLog(@"error to inster data: %@", name);
    32. } else {
    33. NSLog(@"succ to inster data: %@", name);
    34. }
    35. }];
    36. }
    37. });
时间: 2024-10-29 16:23:01

IOS第三方数据库--FMDB的相关文章

iOS开发 数据库FMDB

iOS开发  数据库FMDB 1.简介 需求作用: 如果需要保存大量的结构较为复杂的数据时候, 使用数据库, 例如交规考试项目 常用的数据库: (1)Microsoft SQL Server 2000/2008, 中小企业使用较多 (2)Oracle 比较复杂, 大企业使用较多 (3)Mysql数据库, 网站使用较多 (4)sqlite: 本地数据库, 访问数据足够快, 直接访问文件 足够简单, 功能相对其他数据库软件不是特别齐全, 足够用了  足够小, 系统不超过1M, 适合在移动端上使用 2

iOS开发数据库-FMDB

前言 FMDB是以OC的方式封装了SQLite的C语言API,使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码:对比苹果自带的Core Data框架,更加轻量级和灵活:提供了多线程安全的数据库操作方法,有效地防止数据混乱:FMDB同时兼容ARC和非ARC工程,在编译的时候会自动根据工程配置来调整相关的内存管理代码. 使用方法 FMDB有三个主要的类 FMDatabase 表示一个单独的SQLite数据库. 用来执行SQLite的命令. FMResultSet 表示FMDatabase执行查

[iOS]数据库第三方框架FMDB详细讲解

[iOS]数据库第三方框架FMDB详细讲解 初识FMDB iOS中原生的SQLite API在进行数据存储的时候,需要使用C语言中的函数,操作比较麻烦.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepersistentobjects等. FMDB是一款简洁.易用的封装库.因此,在这里推荐使用第三方框架FMDB,它是对libsqlite3框架的封装,用起来的步骤与SQLite使用类似,并且它对于多线程的并发操作进行了处理,所以

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

iOS开发数据库篇—FMDB简单介绍 一.简单说明 1.什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 2.FMDB的优点 使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码 对比苹果自带的Core Data框架,更加轻量级和灵活 提供了多线程安全的数据库操作方法,有效地防止数据混乱 3.FMDB的github地址 https://github.com/ccgus/fmdb 二.核心类 FMDB有三个主要的类 (1)FMDa

iOS开发数据库篇—FMDB数据库队列(下)

iOS开发数据库篇—FMDB数据库队列(下) 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: 1 // 2 // YYViewController.m 3 // 05-FMDB数据库队列 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "Y

IOS开发之数据库FMDB

IOS开发之数据库FMDB 1.简介 需求作用:如果需要保存大量的结构较为复杂的数据时候, 使用数据库, 例如交规考试项目 常用的数据库: (1)Microsoft SQL Server 2000/2008:中小企业使用较多 (2)Oracle:比较复杂, 大企业使用较多 (3)Mysql数据库:网站使用较多 (4)sqlite:本地数据库, 访问数据足够快, 直接访问文件  足够简单, 功能相对其他数据库软件不是特别齐全, 足够用了  足够小, 系统不超过1M, 适合在移动端上使用 2. Me

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

iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: 1 // 2 // YYViewController.m 3 // 05-FMDB数据库队列 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "YYVi

IOS数据库FMDB增、删、改、查的使用【原创】

http://blog.it985.com/13588.html IOS数据库FMDB增.删.改.查的使用[原创] FMDB是一个XCODE的中一个轻量级的数据库,用于将网络资源存储在本地.所以,FMDB是一个很实用,很关键的知识点.在这里写了个简单的例子,基于FMDB的添删改查操作,代码可能比较乱,希望不要伤了各位的眼睛.其中添加删除更改的操作都非常简单,不需要做太多操作,只需要用到FMDB封装好的executeUpdate方法就行了. 第一步.加入sqlite3的包文件 如图所示,依次选择并

iOS开发之用代码实现数据库FMDB的操作

iOS开发之用代码实现数据库FMDB的操作 1.简介 需求作用: 如果需要保存大量的结构较为复杂的数据时候, 使用数据库, 例如交规考试项目 常用的数据库: (1)Microsoft SQL Server 2000/2008, 中小企业使用较多 (2)Oracle 比较复杂, 大企业使用较多 (3)Mysql数据库, 网站使用较多 (4)sqlite: 本地数据库, 访问数据足够快, 直接访问文件 足够简单, 功能相对其他数据库软件不是特别齐全, 足够用了  足够小, 系统不超过1M, 适合在移