iOS 数据库篇8—FMDB数据库队列
2016-05-30 10:12
302 查看
一、代码示例
1.导入FMDB框架
需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库。2.代码
代码如下:// // YYViewController.m // 05-FMDB数据库队列 // // Created by apple on 14-7-28. // Copyright (c) 2014年 wendingding. All rights reserved. // #import "YYViewController.h" #import "FMDB.h" @interface YYViewController () @property(nonatomic,strong)FMDatabaseQueue *queue; @end @implementation YYViewController - (void)viewDidLoad { [super viewDidLoad]; //1.获得数据库文件的路径 NSString *doc=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject]; NSString *fileName=[doc stringByAppendingPathComponent:@"person.sqlite"]; //2.获得数据库队列 FMDatabaseQueue *queue=[FMDatabaseQueue databaseQueueWithPath:fileName]; // FMDatabase *db=[FMDatabase databaseWithPath:fileName]; //3.打开数据库 [queue inDatabase:^(FMDatabase *db) { BOOL result=[db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_person (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, age integer NOT NULL);"]; if (result) { NSLog(@"创表成功"); }else { NSLog(@"创表失败"); } }]; self.queue=queue; } -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { //插入数据 // [self.queue inDatabase:^(FMDatabase *db) { // [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @22]; // }]; //查询数据 [self.queue inDatabase:^(FMDatabase *db) { // 1.执行查询语句 FMResultSet *resultSet = [db executeQuery:@"SELECT * FROM t_person"]; // 2.遍历结果 while ([resultSet next]) { int ID = [resultSet intForColumn:@"id"]; NSString *name = [resultSet stringForColumn:@"name"]; int age = [resultSet intForColumn:@"age"]; NSLog(@"%d %@ %d", ID, name, age); } }]; } @end
先插入数据,之后查询结果,打印如下:
3.代码说明
有了一个队列对象,它的内部自动就拥有一个数据库对象,且数据库的操作是线程安全的。二、事务
事务,没有事务的话会出现问题。举例:银行的例子
张三和李四账户都有1000块钱,如果张三要转账给李四,需要执行两条SQL语句,考虑到安全性,要求这两条鱼具要么全部执行成功,要不全部执行失败。
事务:把多条语句放到同一个事务中,要么全部成功,要不全部失败(如果中途出现问题,那么会自动回滚)。事务的执行具有原子性。
事务代码处理:
把多条语句添加到一个事务中去执行:
//插入数据 [self.queue inDatabase:^(FMDatabase *db) { [db beginTransaction]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @22]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @23]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @24]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @25]; [db commit]; }];
如果中途出现问题,那么会自动回滚,也可以选择手动回滚。
//插入数据 [self.queue inDatabase:^(FMDatabase *db) { [db beginTransaction]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @22]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @23]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @24]; [db rollback]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @25]; [db commit]; }];
上面的代码。前三条插入语句是作废的。
事务处理的另一种方式:
[self.queue inTransaction:^(FMDatabase *db, BOOL *rollback) { [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @22]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @23]; [db executeUpdate:@"INSERT INTO t_person (name, age) VALUES (?, ?);",@"wendingding", @24]; }];
说明:先开事务,再开始事务,之后执行block中的代码段,最后提交事务。
相关文章推荐
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 不可修补的 iOS 漏洞可能导致 iPhone 4s 到 iPhone X 永久越狱
- iOS 12.4 系统遭黑客破解,漏洞危及数百万用户
- 每日安全资讯:NSO,一家专业入侵 iPhone 的神秘公司
- [转][源代码]Comex公布JailbreakMe 3.0源代码
- 讲解iOS开发中基本的定位功能实现
- iOS中定位当前位置坐标及转换为火星坐标的方法
- js判断客户端是iOS还是Android等移动终端的方法
- iOS应用开发中AFNetworking库的常用HTTP操作方法小结
- iOS应用中UISearchDisplayController搜索效果的用法
- IOS开发环境windows化攻略
- iOS应用中UITableView左滑自定义选项及批量删除的实现
- iOS中UIAlertView警告框组件的使用教程
- 浅析iOS应用开发中线程间的通信与线程安全问题
- 检测iOS设备是否越狱的方法
- .net平台推送ios消息的实现方法
- 探讨Android与iOS,我们将何去何从?
- Android、iOS和Windows Phone中的推送技术详解