首页 > 代码库 > 关于iOS中SQLITE句柄的使用的细节
关于iOS中SQLITE句柄的使用的细节
1、设计思想:给SQLITE进行封装,利用定义的类别实现方法的简洁,以便达到低耦合效果
1 控制器代码: 2 #import "ViewController.h" 3 #import "DatabaseHelper.h" 4 5 @interface ViewController () 6 { 7 sqlite3 *db; 8 } 9 @end10 11 @implementation ViewController12 13 -(void)loadView {14 15 [super loadView];16 self.view.backgroundColor = [UIColor orangeColor];17 }18 - (void)viewDidLoad {19 [super viewDidLoad];20 //PART1:该部分为实现的帮助类别21 //PART1 .122 [DatabaseHelper openDatabaseWithName:@"personinfo.sqlite" withSqlite:db];23 //PART1 .224 db =[DatabaseHelper openDatabaseWithName:@"personinfo.sqlite" withSqlite:db];
25 NSLog(@" isOpenOrCreat = %@",db ?@"sucess":@"failure");
26
27 //PART2:用以判断数据库是否打开
28 if (db) {
29
30 }
31
32 //PART3:用以判断数据库是否打开
33 [DatabaseHelper execSql:@"CREATE TABLE IF NOT EXISTS PERSONINFO (ID INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, address TEXT)" withSqlite:db];
1 操作类代码: 2 #import "DatabaseHelper.h" 3 4 @implementation DatabaseHelper 5 +(sqlite3 *)openDatabaseWithName:(NSString *)name withSqlite:(sqlite3 *)sqlite3{ 6 //PART5: 7 //1、获取Documents文件路径 8 NSString *documentsPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]; 9 //2、拼接要建立的数据库文件路径10 NSString *databasePath = [documentsPath stringByAppendingPathComponent:name];11 //打印12 NSLog(@"databasePath = %@",databasePath);13 //判断是否已经打开(打开失败时关闭数据库并log提示)14 if (sqlite3_open([databasePath UTF8String], &sqlite3) != SQLITE_OK) {15 sqlite3_close(sqlite3);16 NSLog(@"数据库打开失败");17 return nil ;18 }19 20 //PART4:21 // char *err;22 // NSString *sql = @"CREATE TABLE IF NOT EXISTS PERSONINFO (ID INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, address TEXT)";23 // if (sqlite3_exec(sqlite3, [sql UTF8String], NULL, NULL, &err) != SQLITE_OK) {24 // sqlite3_close(sqlite3);25 // NSLog(@"数据库操作数据失败!");26 // NSLog(@"%s ",err);27 // }28 29 return sqlite3;30 }31 32 +(BOOL)execSql:(NSString *)sql withSqlite:(sqlite3 *)sqlite3{33 char *err;34 //sqlite3_exec(), 执行非查询的sql语句35 if (sqlite3_exec(sqlite3, [sql UTF8String], NULL, NULL, &err) != SQLITE_OK) {36 sqlite3_close(sqlite3);37 NSLog(@"数据库操作数据失败!");38 return NO;39 }40 return YES;41 42 }
问题:
1、当注掉PART1.1 数据库可以被写入
2、当注掉PART1.1、PART4 后数据库不能被写入
3、当注掉PART1.2、PART4 数据库可以被写入
结论:
1、句柄的存在必须依赖于上下文,数据库的操作必须依赖于句柄存在的内容。
2、只有句柄前后相对应才能实现对数据库的操作.
关于iOS中SQLITE句柄的使用的细节
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。