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

}



目录
相关文章
|
27天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
185 15
|
2月前
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
53 8
|
3月前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
52 4
|
3月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
78 3
|
3月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
4月前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
247 1
|
3月前
|
存储 缓存 关系型数据库
sqlite 数据库 介绍
sqlite 数据库 介绍
61 0
|
14天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
14天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
42 3
|
14天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
54 2