• FMDB使用简介


    转:http://my.oschina.net/youzaiyouzaie/blog/92325 

    源码地址:https://github.com/ccgus/fmdb

    这次要分享的是在iOS中使用SQLite。其实我对SQLite一点概念都没有,因为一直没有机会使用它。有时候突然想到,就会找几本手边的工具书或在网路上找寻在iOS中使用SQLite的教学。但是每次学,每次失败,让我愈来愈讨厌SQLite 囧。直到有一次在网路上发现了FMDB这个东西,才发现不是SQLite很难学,而是SQLite的C API对初学者来说实在太麻烦太琐碎,难度太高,难怪我怎么学都学不会。FMDB说穿了其实只是把C API包装成简单易用的Objective-C物件。不过这对我这个SQLite初学者来说,可是大大减低了上手的难度。有了FMDB,写程式时只要专心在SQLite的语法上,而不用去理那堆有看没有懂的C API,实在是件快乐的事情。

    废话不多说,先来安装FMDB吧http://www.myexception.cn/!

    首先到这里下载FMDB的source code,接着在解开的档案里,把src资料夹下除了fmdb.m的档案加入到自己的iOS专案,最后在专案中加入libsqlite3.dylib这个函式库就可以了。啥?有人问为什么不用加入fmdb.m?简单讲,这个档案是fmdb的使用说明。里面的注解清楚,范例又简单,如果有兴趣,直接看fmdb.m,大概就会用fmdb了。

    以下介绍几个常用的指令,分享给大家:

    -开启/关闭资料库

    使用资料库的第一件事,就是建立一个资料库。要注意的是,在iOS环境下,只有document directory 是可以进行读写的。在写程式时用的那个Resource资料夹底下的东西都是read-only。因此,建立的资料库要放在document 资料夹下。方法如下:

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

    NSString *documentDirectory = [paths objectAtIndex:0];

    NSString *dbPath = [documentDirectory stringByAppendingPathComponent:@"MyDatabase.db"];

    FMDatabase

    *db = [FMDatabase databaseWithPath:dbPath] ;

    if (![db open]) {

    NSLog(@“Could not open db.”);

    return ;

    }

    通常这段程式码会放在UIViewController中viewDidLoad的函式里。指定路径后,用[FMDatabase databaseWithPath:]回传一个FMDatabase物件,如果该路径本来没有档案,会新增档案,不然会开启旧档。最后呼叫[db open]可以开启该资料库档案,[db close]则关闭该档案。

    -建立table

    如果是新建的资料库档,一开始是没有table的。建立table的方式很简单:

    [db executeUpdate:@"CREATE TABLE PersonList (Name text, Age integer, Sex integer, Phone text, Address text, Photo blob)"];

    这是FMDB里很常用的指令,[ FMDatabase_object executeUpdate:]后面用NSString塞入SQLite语法,就解决了。因为这篇主要是在讲FMDB,所以SQLite的语法就不多说了,上述程式码建立了一个名为PersonList的table,里面有姓名、年龄、性别、电话、地址和照片。(嗯….很范例的一个table)

    -插入资料

    插入资料跟前面一样,用executeUpdate后面加语法就可以了。比较不同的是,因为插入的资料会跟Objective-C的变数有关,所以在string里使用?号来代表这些变数。

    [db executeUpdate:@"INSERT INTO PersonList (Name, Age, Sex, Phone, Address, Photo) VALUES (?,?,?,?,?,?)",

    @"Jone", [NSNumber numberWithInt:20], [NSNumber numberWithInt:0], @“091234567”, @“Taiwan, ROC”, [NSData dataWithContentsOfFile:? filepath ]];

    其中,在SQLite中的text对应到的是NSString,integer对应NSNumber,blob则是NSData。该做的转换FMDB都做好了,只要了解SQLite语法,应该没有什么问题才是。

    -更新资料

    太简单了,不想讲,请看范例:

    [db executeUpdate:@"UPDATE PersonList SET Age = ? WHERE Name = ?",[NSNumber numberWithInt:30],@“John”];

    -取得资料

    取得特定的资料,则需使用FMResultSet物件接收传回的内容:

    FMResultSet *rs = [db executeQuery:@"SELECT Name, org.apache.jasper.JasperException: For input stringAge, FROM PersonList"];

    while ([rs next]) {

    NSString *name = [rs stringForColumn:@"Name"];

    int age = [rs intForColumn:@"Age"];

    }

    [rs close];

    用[rs next]可以轮询query回来的资料,每一次的next可以得到一个row里对应的数值,并用[rs stringForColumn:]或[rs intForColumn:]等方法把值转成Object-C的型态。取用完资料后则用[rs close]把结果关闭。

    -快速取得资料

    在有些时候,只会query某一个row里特定的一个数值(比方只是要找John的年龄),FMDB提供了几个比较简便的方法。这些方法定义在FMDatabaseAdditions.h,如果要使用,记得先import进来。

    //找地址

    NSString *address = [db stringForQuery:@"SELECT Address FROM PersonList WHERE Name = ?",@"John”];

    //找年龄

    int age = [db intForQuery:@"SELECT Age FROM PersonList WHERE Name = ?",@"John”];

    大概就是这样啰~对于在Objective-C上使用SQLite有困难的朋友,看完之后是不是觉得一切都变的很简单呢?赶快去试试吧~

    网上找了很多,大多都一样,这个是我见到讲的最深入的了,希望对和我一样的菜鸟们有帮助,大家一起学习,分享,进步,加油!

    另这里的部分程序错误异常BUG解决方案

    java环境变量设置|http://www.myexception.cn/java-other/172921.html

    oracle存储过程|http://www.myexception.cn/oracle-develop/177537.html

  • 相关阅读:
    使用createDocumentFragment的渲染数据(节省性能)
    面向对象写法模板
    面向对象this指向
    js 3D图片叠加旋转切换
    三列布局-中间固定俩边自适应-和两边固定中间自适应布局
    游戏中抽奖的算法
    c++11:lambda表达式
    c++11:模板
    c++11:左值、右值
    游戏服务器语言之争
  • 原文地址:https://www.cnblogs.com/ygm900/p/4449806.html
Copyright © 2020-2023  润新知