【iOS开发-105】SQLite第三方框架FMDB的使用,以及使用FMDatabaseQueue保证线程安全

【iOS开发-105】SQLite第三方框架FMDB的使用,以及使用FMDatabaseQueue保证线程安全,第1张

概述(1)下载地址:https://github.com/ccgus/fmdb (2)注意点 ——语句可以带分号“;”,也可以省略分号。 ——同样需要添加“libsqlite3.dylib”库才能使用。 ——移动端的开发中,一般不关闭数据库,即不怎么使用[self.db close];,因为每次重新打开比较耗性能,且每次程序关闭时数据库自然会同时关闭。 (3)用法 #import "ViewContr

(1)下载地址:https://github.com/ccgus/fmdb


(2)注意点

——语句可以带分号“;”,也可以省略分号。

——同样需要添加“libsqlite3.dylib”库才能使用。

——移动端的开发中,一般不关闭数据库,即不怎么使用[self.db close];,因为每次重新打开比较耗性能,且每次程序关闭时数据库自然会同时关闭。


(3)用法

#import "VIEwController.h"#import "FMDB.h"@interface VIEwController ()@property(nonatomic,strong) FMDatabase *db;- (IBAction)insert:(ID)sender;- (IBAction)delete:(ID)sender;- (IBAction)update:(ID)sender;- (IBAction)select:(ID)sender;@end@implementation VIEwController- (voID)vIEwDIDLoad {    [super vIEwDIDLoad];    Nsstring *filePath=[[NSSearchPathForDirectorIEsInDomains(NSdocumentDirectory,NSUserDomainMask,YES) lastObject] stringByAppendingPathComponent:@"fmdb.sqlite"];    //创建数据库    self.db=[FMDatabase databaseWithPath:filePath];    //打开数据库    if ([self.db open]) {        NSLog(@"打开数据库成功");        //创建表格,除了select外,所有的 *** 作都是更新        BOol createtableResult=[self.db executeUpdate:@"CREATE table IF NOT EXISTS t_student (ID integer PRIMARY KEY autoINCREMENT,name text,age integer)"];        if (createtableResult) {            NSLog(@"创建表成功");        }else{            NSLog(@"创建表失败");        }    }else{        NSLog(@"打开数据库失败");    }}- (IBAction)insert:(ID)sender {    for (int index=0; index<50; index++) {        Nsstring *s_name=[Nsstring stringWithFormat:@"Andy%d",arc4random()%100];        NSNumber *s_age=@(arc4random()%100);        [self.db executeUpdate:@"INSERT INTO t_student(name,age) VALUES(?,?)",s_name,s_age];    }}- (IBAction)delete:(ID)sender {    [self.db executeUpdate:@"DELETE FROM t_student WHERE ID=?",@1];}- (IBAction)update:(ID)sender {    [self.db executeUpdate:@"UPDATE t_student SET name='Jack' WHERE ID=?",@2];}- (IBAction)select:(ID)sender {    //获取结果集,返回参数就是查询结果    FMResultSet *rs=[self.db executequery:@"SELECT * FROM t_student WHERE age>?",@50];    while ([rs next]) {        int ID=[rs intForColumn:@"ID"];        Nsstring *name=[rs stringForColumn:@"name"];        int AGE=[rs intForColumn:@"age"];        NSLog(@"%d %@ %d",ID,name,AGE);    }}@end

(4)使用FMDatabaseQueue保证线程安全(建议以后都这么做)

——主要就是在创建数据库的时候,默认已经打开数据库

——随后的很多 *** 作,因为需要在数据库中 *** 作,所以需要利用队列的inDataBase方法调出数据库,在block中执行 *** 作代码。

#import "VIEwController.h"#import "FMDB.h"@interface VIEwController ()@property(nonatomic,strong) FMDatabaseQueue *queue;- (IBAction)insert:(ID)sender;- (IBAction)delete:(ID)sender;- (IBAction)update:(ID)sender;- (IBAction)select:(ID)sender;@end@implementation VIEwController- (voID)vIEwDIDLoad {    [super vIEwDIDLoad];    Nsstring *filePath=[[NSSearchPathForDirectorIEsInDomains(NSdocumentDirectory,YES) lastObject] stringByAppendingPathComponent:@"fmdb.sqlite"];    //创建数据库,并加入到队列中,此时已经默认打开了数据库,无须手动打开,只需要从队列中去除数据库即可    self.queue=[FMDatabaseQueue databaseQueueWithPath:filePath];    //取出数据库,这里的db就是数据库,在数据库中创建表    [self.queue inDatabase:^(FMDatabase *db) {        //创建表        BOol createtableResult=[db executeUpdate:@"CREATE table IF NOT EXISTS t_student (ID integer PRIMARY KEY autoINCREMENT,age integer)"];        if (createtableResult) {            NSLog(@"创建表成功");        }else{            NSLog(@"创建表失败");        }    }];}- (IBAction)insert:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        for (int index=0; index<50; index++) {            Nsstring *s_name=[Nsstring stringWithFormat:@"Andy%d",arc4random()%100];            NSNumber *s_age=@(arc4random()%100);            [db executeUpdate:@"INSERT INTO t_student(name,s_age];        }    }];}- (IBAction)delete:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        [db executeUpdate:@"DELETE FROM t_student WHERE ID=?",@1];    }];}- (IBAction)update:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        [db executeUpdate:@"UPDATE t_student SET name='Jack' WHERE ID=?",@2];    }];}- (IBAction)select:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        //获取结果集,返回参数就是查询结果        FMResultSet *rs=[db executequery:@"SELECT * FROM t_student WHERE age>?",@50];        while ([rs next]) {            int ID=[rs intForColumn:@"ID"];            Nsstring *name=[rs stringForColumn:@"name"];            int AGE=[rs intForColumn:@"age"];            NSLog(@"%d %@ %d",AGE);        }    }];}

(5)如果要保证多个 *** 作同时成功或者同时失败,用事务,即把多个 *** 作放在同一个事务中。

——FMDB中,拿到数据库直接 *** 作事务,如下:

- (IBAction)update:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        [db beginTransaction];        [db executeUpdate:@"UPDATE t_student SET name='Jack' WHERE ID=?",@2];        [db executeUpdate:@"UPDATE t_student SET name='Tomy' WHERE ID=?",@3];        //发现情况不对时,主动回滚用下面语句。否则是根据commit结果,如成功就成功,如不成功才回滚        [db rollback];        [db executeUpdate:@"UPDATE t_student SET name='Eric' WHERE ID=?",@4];        [db commit];    }];}

上面因为用的是FMDB封装好的,其实原生的代码是这样的:
[db executeUpdate:@"BEGIN TRANSACTION"];[db executeUpdate:@"RolLBACK TRANSACTION"];[db executeUpdate:@"COMMIT TRANSACTION"];

——FMDB中,也可以直接利用队列进行事务 *** 作,队列中的打开、关闭、回滚事务等都已经被封装好了。

- (IBAction)update:(ID)sender {    [self.queue inDatabase:^(FMDatabase *db) {        [self.queue inTransaction:^(FMDatabase *db,BOol *rollback) {            [db executeUpdate:@"UPDATE t_student SET name='Jack' WHERE ID=?",@2];            [db executeUpdate:@"UPDATE t_student SET name='Tomy' WHERE ID=?",@3];            //发现情况不对时,主动回滚用下面语句。            *rollback=YES;            [db executeUpdate:@"UPDATE t_student SET name='Eric' WHERE ID=?",@4];        }];}
总结

以上是内存溢出为你收集整理的【iOS开发-105】SQLite第三方框架FMDB的使用,以及使用FMDatabaseQueue保证线程安全全部内容,希望文章能够帮你解决【iOS开发-105】SQLite第三方框架FMDB的使用,以及使用FMDatabaseQueue保证线程安全所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1179716.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存