使用iOS原生sqlite3框架对sqlite数据库进行操作(三)

简介: 使用iOS原生sqlite3框架对sqlite数据库进行操作

4.数据库操作对象


       将操作数据库的核心方法封装在这个类中:


YHBaseSQLiteContext.h


/**

*操作的数据库名称

*/

@property(nonatomic,strong)NSString * name;

/**

*内含sqlite3 对象

*/

@property(nonatomic,assign)sqlite3 * sqlite3_db;

/**

* @brief 打开一个数据库 不存在则创建

*

* @param path 数据库路径

*

* @return 是否操作成功

*/

-(BOOL)openDataBaeWithName:(NSString *)path;

/**

*  @brief 再数据库中创建一张表 如果已经存在 会返回错误信息

*

*  @param name 表的名称

*

*  @prarm dic 表中的键 其中字典中需传入 键名:类型  类型的宏定义在YHBaseSQLTypeHeader.h中

*

*  @param callBack 结果回调

*/

-(void)createTableWithName:(NSString *)name

           keysDictionary:(NSDictionary<NSString*,NSString*> *) dic

                 callBack:(void (^)(YHBaseSQLError * error))complete;


/**

*  @brief 向表中添加一条数据

*

*  @param dataDic 添加数据的键值对

*

*  @param name 插入表的名称

*

*  @complete 回调

*/

-(void)insertData:(NSDictionary<NSString *,id>*)dataDic

       intoTable:(NSString *)name

        callBack:(void (^)(YHBaseSQLError * error))complete;

/**

*  @brief 向表中添加一个键

*

*  @param kName 添加的键

*

*  @prarm type 类型

*

*  @prarm tableName 表名称

*

*  @prarm complete 结果回调

*/

-(void)addKey:(NSString *)kName

     keyType:(NSString *)type

   intoTable:(NSString *)tableName

    callBack:(void(^)(YHBaseSQLError *error))complete;

/**

*  @brief 修改数据

*

*  @param dataDic 新的键值

*

*  @param wlStr 条件字符串 一般通过主键找到对应数据修改 可以为nil

*

*  @param complete 结果回调

*/

-(void)update:(NSDictionary<NSString*,id> *)dataDic

     inTable:(NSString *)tableName

 whileString:(NSString *)wlStr

    callBack:(void(^)(YHBaseSQLError * error))complete;

/**

*  @brief 删除数据

*

*  @param tableName 表名

*

*  @param wlStr 条件字符串 一般通过主键找到对应数据删除 可以为nil 不传这个参数将删除所有数据

*

*/

-(void)deleteDataFromTable:(NSString *)tableName

              whereString:(NSString *)wlStr

                 callBack:(void(^)(YHBaseSQLError * error))complete;

/**

*  @brief 删除一张表

*

*  @param tableName 表名

*

*/

-(void)dropTable:(NSString *)tableName

       callBack:(void(^)(YHBaseSQLError * error))complete;

/**

*  @brief 查询数据

*

*  @param keys 要查询的键值 及其对应的数据类型 可以为nil则查询全部

*

*  @param tableName 表名

*

*  @param orderKey 进行排序的键值 可以为nil 则不排序

*

*  @param type 排序方式 在YHBaseSQLTypeHeader中有宏定义

*

*  @param wlstr 查询条件 同于查询单个数据

*

*  @param complete dataArray为查询到的数据 其内为字典

*

*/

-(void)selectKeys:(NSArray<NSDictionary *> *)keys

       fromTable:(NSString*)tableName

         orderBy:(NSString *)orderKey

       orderType:(NSString *)type

        whileStr:(NSString *)wlstr

        callBack:(void(^)(NSArray<NSDictionary *> * dataArray,YHBaseSQLError * error))complete;

/**

*  @brief 关闭数据库上下文操作

*  调用此方法后 这个context对象将不再有效 如果再需要使用 需要YHBaseSQLiteManager中的类方法再次返回

*/

-(void)closeContext;


YHBaseSQLiteContext.m


-(BOOL)openDataBaeWithName:(NSString *)path{

   if (sqlite3_open([path UTF8String], &_sqlite3_db)!=SQLITE_OK) {

       sqlite3_close(_sqlite3_db);

       _sqlite3_db=nil;

       return NO;

   }else{

       return YES;

   }

}

-(void)createTableWithName:(NSString *)name keysDictionary:(NSDictionary<NSString *,NSString *> *)dic callBack:(void (^)(YHBaseSQLError *))complete{

   NSMutableString * keys = [[NSMutableString alloc]init];

   for (int i=0; i<dic.allKeys.count; i++) {

       NSString * key = dic.allKeys[i];

       if (i<dic.allKeys.count-1) {

           [keys appendFormat:@"%@ %@,",key,[dic objectForKey:key]];

       }else{

           [keys appendFormat:@"%@ %@",key,[dic objectForKey:key]];

       }

   }

   NSString * sqlStr = [NSString stringWithFormat:@"create table %@(%@)",name,keys];

   [self runSQL:sqlStr callBack:^(YHBaseSQLError * error) {

     

       if (complete) {

           complete(error);

       }

     

   }];

}

-(void)insertData:(NSDictionary<NSString *,id> *)dataDic intoTable:(NSString *)name callBack:(void (^)(YHBaseSQLError *))complete{

   NSMutableString * keys = [[NSMutableString alloc]init];

   NSMutableString * values = [[NSMutableString alloc]init];

   for (int i=0; i<dataDic.allKeys.count; i++) {

       NSString * key = dataDic.allKeys[i];

       if (i<dataDic.count-1) {

           [keys appendFormat:@"%@,",key];

           [values appendFormat:@"\"%@\",",[dataDic objectForKey:key]];

       }else{

           [keys appendFormat:@"%@",key];

           [values appendFormat:@"\"%@\"",[dataDic objectForKey:key]];

       }

   }

   NSString * sqlStr = [NSString stringWithFormat:@"insert into %@(%@) values(%@)",name,keys,values];

   [self runSQL:sqlStr callBack:^(YHBaseSQLError *error) {

     

       if (complete) {

           complete(error);

       }

     

   }];

}

-(void)addKey:(NSString *)kName keyType:(NSString *)type intoTable:(NSString *)tableName callBack:(void (^)(YHBaseSQLError *))complete{

   NSString * sqlStr = [NSString stringWithFormat:@"alter table %@ add %@ %@",tableName,kName,type];

   [self runSQL:sqlStr callBack:^(YHBaseSQLError *error) {

       if (complete) {

           complete(error);

       }

   }];

}

-(void)update:(NSDictionary<NSString *,id> *)dataDic inTable:(NSString *)tableName whileString:(NSString *)wlStr callBack:(void (^)(YHBaseSQLError *))complete{

   NSMutableString * sqlStr = [[NSMutableString alloc]init];

   [sqlStr appendFormat:@"update %@ set ",tableName];

   for (int i=0; i<dataDic.allKeys.count; i++) {

       NSString * key = dataDic.allKeys[i];

       if (i<dataDic.allKeys.count-1) {

           [sqlStr appendFormat:@"%@=\"%@\",",key,[dataDic objectForKey:key]];

       }else{

           [sqlStr appendFormat:@"%@=\"%@\"",key,[dataDic objectForKey:key]];

           if (wlStr!=nil) {

               [sqlStr appendFormat:@" where %@",wlStr];

           }

       }

   }

   [self runSQL:sqlStr callBack:^(YHBaseSQLError *error) {

       if (complete) {

           complete(error);

       }

   }];

}



-(void)deleteDataFromTable:(NSString *)tableName whereString:(NSString *)wlStr callBack:(void (^)(YHBaseSQLError *))complete{

   NSMutableString * sqlStr = [[NSMutableString alloc]init];

   [sqlStr appendFormat:@"delete from %@",tableName];

   if (wlStr!=nil) {

       [sqlStr appendFormat:@" where %@",wlStr];

   }

   [self runSQL:sqlStr callBack:^(YHBaseSQLError *error) {

       if (complete) {

           complete(error);

       }

   }];

}

-(void)dropTable:(NSString *)tableName callBack:(void (^)(YHBaseSQLError *))complete{

   NSString * sqlStr = [NSString stringWithFormat:@"drop table %@",tableName];

   [self runSQL:sqlStr callBack:^(YHBaseSQLError *error) {

       if (complete) {

           complete(error);

       }

   }];

}

-(void)selectKeys:(NSArray<NSDictionary *> *)keys fromTable:(NSString *)tableName orderBy:(NSString *)orderKey orderType:(NSString *)type whileStr:(NSString *)wlstr callBack:(void (^)(NSArray<NSDictionary *> *, YHBaseSQLError *))complete{

   NSMutableString * sqlStr = [[NSMutableString alloc]init];

   [sqlStr appendFormat:@"select"];

   if (keys==nil||keys.count==0) {

       [sqlStr appendFormat:@" * from %@",tableName];

   }else{

       for (int i=0; i<keys.count; i++) {

           if (i<keys.count-1) {

               [sqlStr appendFormat:@" %@,",keys[i].allKeys.firstObject];

           }else{

               [sqlStr appendFormat:@" %@ from %@",keys[i].allKeys.firstObject,tableName];

           }

         

       }

   }

   if (wlstr) {

       [sqlStr appendFormat:@" where %@",wlstr];

   }

   if (orderKey) {

       [sqlStr appendFormat:@" order by %@",orderKey];

   }

   if (type) {

       [sqlStr appendFormat:@" %@",type];

   }

   NSMutableArray * keysArr = [[NSMutableArray alloc]init];

   NSMutableArray * keysTypeArr = [[NSMutableArray alloc]init];

   if (keys==nil||keys.count==0) {

       NSArray<NSDictionary *> * tmpArr = [self getTheTableAllKeys:tableName];

       for (int i=0; i<tmpArr.count; i++) {

           NSString * key = tmpArr[i].allKeys.firstObject;

           [keysArr addObject:key];

           [keysTypeArr addObject:[tmpArr[i] objectForKey:key]];

       }

   }else{

       for (int i=0; i<keys.count; i++) {

           NSString * key = keys[i].allKeys.firstObject;

           [keysArr addObject:key];

           [keysTypeArr addObject:[keys[i] objectForKey:key]];

       }

   }

 

   [self runSelectSQL:sqlStr withKeys:keysArr withDataType:keysTypeArr callBack:^(NSArray<NSDictionary *> *dataArray, YHBaseSQLError *error) {

       if (complete) {

           complete(dataArray,error);

       }

   }];

 

}

-(void)closeContext{

   sqlite3_close(_sqlite3_db);

   _sqlite3_db = nil;

}


//内部方法 运行创建独立的非查询SQL语句

-(void)runSQL:(NSString *)sql callBack:(void(^)(YHBaseSQLError * error))complete{

   char * err;

   int code = sqlite3_exec(_sqlite3_db, [sql UTF8String], NULL, NULL, &err);

   if (code!=SQLITE_OK) {

       YHBaseSQLError * error = [[YHBaseSQLError alloc]init];

       error.errorInfo = [NSString stringWithCString:err encoding:NSUTF8StringEncoding];

       error.errorCode = code;

       complete(error);

   }else{

       complete(nil);

   }

}

//运行查询语句

-(void)runSelectSQL:(NSString *)sql withKeys:(NSArray *)keys withDataType:(NSArray *)dataType callBack:(void(^)(NSArray<NSDictionary *> * dataArray, YHBaseSQLError * error))complete{

   sqlite3_stmt *stmt =nil;

   int code = sqlite3_prepare_v2(_sqlite3_db, [sql UTF8String], -1, &stmt, NULL);

   if (code!=SQLITE_OK) {

       YHBaseSQLError * error = [[YHBaseSQLError alloc]init];

       error.errorInfo = @"查询失败";

       error.errorCode=code;

       complete(nil,error);

   }else{

       NSMutableArray * resultArray = [[NSMutableArray alloc]init];

     

       while (sqlite3_step(stmt)==SQLITE_ROW) {

           //数据类型的分别解析

           NSMutableDictionary * dic = [[NSMutableDictionary alloc]init];

           for (int i=0; i<dataType.count; i++) {

               NSString * type = dataType[i];

               if ([type isEqualToString:YHBASE_SQL_DATATYPE_BINARY]) {

                   int length = sqlite3_column_bytes(stmt, i);

                   const void *data = sqlite3_column_blob(stmt, i);

                   NSData * value = [NSData dataWithBytes:data length:length];

                   [dic  setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_BLOB]){

                   int length = sqlite3_column_bytes(stmt, i);

                   const void *data = sqlite3_column_blob(stmt, i);

                   NSData * value = [NSData dataWithBytes:data length:length];

                   [dic  setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_BOOLEAN]){

                   NSNumber * value = [NSNumber numberWithInt:sqlite3_column_int(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_CURRENCY]){

                   NSNumber * value = [NSNumber numberWithLong:sqlite3_column_int64(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_DATE]){

                   char * cString =(char*)sqlite3_column_text(stmt, i);

                   NSString * value = [NSString stringWithCString:cString?cString:"NULL" encoding:NSUTF8StringEncoding];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_DOUBLE]){

                   NSNumber * value = [NSNumber numberWithFloat:sqlite3_column_double(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_FLOAT]){

                   NSNumber * value = [NSNumber numberWithFloat:sqlite3_column_double(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_INTRGER]){

                 

                   NSNumber * value = [NSNumber numberWithInt:sqlite3_column_int(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_REAL]){

                   NSNumber * value = [NSNumber numberWithDouble:sqlite3_column_int(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_SMALLINT]){

                   NSNumber * value = [NSNumber numberWithShort:sqlite3_column_int(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_TEXT]){

                   char * cString =(char*)sqlite3_column_text(stmt, i);

                   NSString * value = [NSString stringWithCString:cString?cString:"NULL" encoding:NSUTF8StringEncoding];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_TIME]){

                   char * cString =(char*)sqlite3_column_text(stmt, i);

                   NSString * value = [NSString stringWithCString:cString?cString:"NULL" encoding:NSUTF8StringEncoding];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_TIMESTAMP]){

                   NSNumber * value = [NSNumber numberWithLongLong:sqlite3_column_int64(stmt, i)];

                   [dic setObject:value forKey:keys[i]];

               }else if([type isEqualToString:YHBASE_SQL_DATATYPE_VARCHAR]){

                   char * cString =(char*)sqlite3_column_text(stmt, i);

                   NSString * value = [NSString stringWithCString:cString?cString:"NULL" encoding:NSUTF8StringEncoding];

                   [dic setObject:value forKey:keys[i]];

               }

           

           }

            [resultArray addObject:dic];

       }

        sqlite3_finalize(stmt);

       stmt=nil;

       complete(resultArray,nil);

   }

}

//获取表中所有字段名和类型

-(NSArray<NSDictionary *> *)getTheTableAllKeys:(NSString *)tableName{

   NSMutableArray * array = [[NSMutableArray alloc]init];

   NSString * getColumn = [NSString stringWithFormat:@"PRAGMA table_info(%@)",tableName];

   sqlite3_stmt *statement;

   sqlite3_prepare_v2(_sqlite3_db, [getColumn UTF8String], -1, &statement, nil);

   while (sqlite3_step(statement) == SQLITE_ROW) {

       char *nameData = (char *)sqlite3_column_text(statement, 1);

       NSString *columnName = [[NSString alloc] initWithUTF8String:nameData];

       char *typeData = (char *)sqlite3_column_text(statement, 2);

       NSString *columntype = [NSString stringWithCString:typeData encoding:NSUTF8StringEncoding];

       NSDictionary * dic = @{columnName:columntype};

       [array addObject:dic];

   }

    sqlite3_finalize(statement);

   statement=nil;

   return array;

}

目录
相关文章
|
2月前
|
搜索推荐 数据管理 定位技术
iOS应用开发中有多种主流框架
iOS应用开发中有多种主流框架
212 60
|
21天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
113 66
|
5月前
|
物联网 区块链 vr&ar
未来已来:探索区块链、物联网与虚拟现实技术的融合与应用安卓与iOS开发中的跨平台框架选择
【8月更文挑战第30天】在科技的巨轮下,新技术不断涌现,引领着社会进步。本文将聚焦于当前最前沿的技术——区块链、物联网和虚拟现实,探讨它们各自的发展趋势及其在未来可能的应用场景。我们将从这些技术的基本定义出发,逐步深入到它们的相互作用和集成应用,最后展望它们如何共同塑造一个全新的数字生态系统。
|
2月前
|
iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第39天】在苹果的生态系统中,SwiftUI框架以其声明式语法和易用性成为开发者的新宠。本文将深入SwiftUI的核心概念,通过实际案例展示如何利用这一框架快速构建用户界面,并探讨其对iOS应用开发流程的影响。
|
2月前
|
开发框架 Dart Android开发
安卓与iOS的跨平台开发:Flutter框架深度解析
在移动应用开发的海洋中,Flutter作为一艘灵活的帆船,正引领着开发者们驶向跨平台开发的新纪元。本文将揭开Flutter神秘的面纱,从其架构到核心特性,再到实际应用案例,我们将一同探索这个由谷歌打造的开源UI工具包如何让安卓与iOS应用开发变得更加高效而统一。你将看到,借助Flutter,打造精美、高性能的应用不再是难题,而是变成了一场创造性的旅程。
|
3月前
|
移动开发 网络协议 小程序
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v9.1版已发布
RainbowChat是一套基于开源IM聊天框架 MobileIMSDK 的产品级移动端IM系统。RainbowChat源于真实运营的产品,解决了大量的屏幕适配、细节优化、机器兼容问题
71 5
|
3月前
|
Swift iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】在苹果生态系统中,SwiftUI的引入无疑为iOS应用开发带来了革命性的变化。本文将通过深入浅出的方式,带领读者了解SwiftUI的基本概念、核心优势以及如何在实际项目中运用这一框架。我们将从一个简单的例子开始,逐步深入到更复杂的应用场景,让初学者能够快速上手,同时也为有经验的开发者提供一些深度使用的技巧和策略。
57 1
|
4月前
|
iOS开发 开发者 UED
探索iOS应用开发中的SwiftUI框架
【9月更文挑战第26天】 在iOS开发的海洋中,SwiftUI犹如一艘现代的快艇,引领着开发者们驶向更加高效与直观的编程体验。本文将带你领略SwiftUI的魅力,从其设计理念到实际应用,我们将一步步揭开它如何简化界面构建过程的面纱。通过对比传统方式,你将看到SwiftUI如何让代码变得像诗一样优美,同时保持强大的功能性和灵活性。准备好让你的iOS开发技能加速升级,一起驾驭这股新潮流吧!
|
4月前
|
前端开发 iOS开发 开发者
探索iOS开发中的SwiftUI框架
【9月更文挑战第21天】在iOS应用开发的广阔天地中,SwiftUI框架如一股清新之风,为开发者带来了声明式语法的便捷与高效。本文将深入探讨SwiftUI的核心概念、布局方式及数据绑定机制,同时通过实例演示如何运用SwiftUI构建用户界面,旨在引领读者领略SwiftUI的魅力,并激发其对iOS开发新趋势的思考与实践。
50 6
|
4月前
|
开发工具 Swift iOS开发
探索iOS开发中的SwiftUI框架
【9月更文挑战第1天】在本文中,我们将一起潜入iOS开发的海洋,特别聚焦于SwiftUI这一现代且富有表现力的框架。SwiftUI不仅简化了界面设计流程,还为开发者提供了声明式Swift语法的便利。通过这篇文章,你将学会如何利用SwiftUI构建灵活且响应式的用户界面,并理解其背后的原理。无论你是刚入门的新手还是寻求进阶的开发者,本文都将为你提供有价值的指导和启示。

热门文章

最新文章