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

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

三、面向对象的sqlite数据库操作框架封装


       网上不乏有许多优秀的第三方sqlite数据库使用框架,FFDM就是其中之一,并且apple自带的coreData也十分优秀。这篇博客中所述内容并不全面,代码也并不十分完善健壮,封装出来的代码除了能够完成基本的数据库操作外,更多主要是对设计思路的示例。


1.面向对象的sqlite管理类的设计思路


       为了便于使用,在设计时,我们尽量将libsqlite3中的方法不暴漏在使用层,通过面向应用的接口来进行方法的设计,设计思路类图如下:


image.png


图中,文件管理中心对文件进行存取删改管理,不暴漏在外,数据库管理中心负责对数据库的创建,删除打开等操作,具体的数据操作由数据库操作对象来完成。


2.文件管理中心方法的编写


       文件管理中心主要负责对数据库文件的存取,可以实现如下方法:


YHBaseCecheCenter.h


/**

*  @brief 获取数据库方法的地址

*

*  @return 地址字符串

*

*/

-(NSString *)getDataBaseFilePath;

/**

*  @brief 获取某个数据库的大小

*

*  @param name 数据库名称

*

*  @return 文件大小 单位M

*

*/

-(float)getSizeFromDataBaseName:(NSString *)name;


YHBaseCecheCenter.m


-(NSString *)getDataBaseFilePath{

   return NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES).firstObject;

}

-(float)getSizeFromDataBaseName:(NSString *)name{

   NSString * path = [NSString stringWithFormat:@"/%@/%@",NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES).firstObject,name];

   return  [self fileSizeAtPath:path]/(1024.0*1024.0);

}

//获取文件大小

- (long long) fileSizeAtPath:(NSString*) filePath{

   NSFileManager* manager = [NSFileManager defaultManager];

   if ([manager fileExistsAtPath:filePath]){

       return [[manager attributesOfItemAtPath:filePath error:nil] fileSize];

   }

   return 0;

}


在iOS系统中因为其沙盒结构的限制,数据库必须方法documents目录下才能正常打开使用。


3.数据库管理中心的设计


       数据库管理中心主要负责对数据库的宏观操作,采用类方法的设计模式,如下


YHBaseSQLiteManager.h


/**

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

*

*  @param name 数据库名称

*

*  @return 数据库操作对象 如果创建失败会返回nil

*

*/

+(YHBaseSQLiteContext *)openSQLiteWithName:(NSString *)name;

/**

*  @brief 获取数据库文件的大小 单位M

*

*  @param dataBase 数据库上下文对象

*

*  @return 数据库文件大小

*/

+(float)getSizeOfDataBase:(YHBaseSQLiteContext *)dataBase;

/**

*  @brief 获取数据库文件的大小 单位M

*

*  @param dataBaseName 数据库名称

*

*  @return 数据库文件大小

*/

+(float)getSizeOfDataBaseName:(NSString *)dataBaseName;

/**

*  @brief 删除所有数据库

*

*/

+(void)removeDataBase;


YHBaseSQLiteManager.m


+(YHBaseSQLiteContext *)openSQLiteWithName:(NSString *)name{

 

   NSString * path =  [[YHBaseCecheCenter sharedTheSingletion]getDataBaseFilePath];

   YHBaseSQLiteContext * context = [[YHBaseSQLiteContext alloc]init];

   context.name = name;

   BOOL success = [context openDataBaeWithName:[NSString stringWithFormat:@"%@/%@",path,name]];

   if (success) {

       return context;

   }else{

       return nil;

   }

}

+(float)getSizeOfDataBase:(YHBaseSQLiteContext *)dataBase{

   return [[YHBaseCecheCenter sharedTheSingletion]getSizeFromDataBaseName:dataBase.name];

}

+(float)getSizeOfDataBaseName:(NSString *)dataBaseName{

   return [[YHBaseCecheCenter sharedTheSingletion]getSizeFromDataBaseName:dataBaseName];

}

+(void)removeDataBase{

   NSString * path =  [[YHBaseCecheCenter sharedTheSingletion]getDataBaseFilePath];

   return [[YHBaseCecheCenter sharedTheSingletion]removeCacheFromPath:path];

}



目录
相关文章
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
1303 4
|
10月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
9月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
552 14
|
Linux 测试技术 数据库
解决django与sqlite3不兼容报SQLite 3.9.0 or later is required (found 3.8.2)错的问题
解决django与sqlite3不兼容报SQLite 3.9.0 or later is required (found 3.8.2)错的问题
704 2
|
Oracle 关系型数据库 Java
实时计算 Flink版操作报错合集之cdc postgres数据库,当表行记录修改后报错,该如何修改
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
SQL 监控 关系型数据库
实时计算 Flink版操作报错合集之在设置监控PostgreSQL数据库时,将wal_level设置为logical,出现一些表更新和删除操作报错,怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
关系型数据库 Java 数据库
实时计算 Flink版操作报错合集之flinksql采PG数据库时报错,该如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之在处理PostgreSQL数据库遇到报错。该如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
存储 小程序 关系型数据库
原生小程序 获取手机号并进行存储到mysql数据库
原生小程序 获取手机号并进行存储到mysql数据库
|
存储 监控 安全
安全规范问题之跟数据库交互涉及的敏感数据操作需要有哪些措施
安全规范问题之跟数据库交互涉及的敏感数据操作需要有哪些措施