使用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];

}



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

热门文章

最新文章