iOS——FMDB的介绍与使用

2023-11-05 21:36
文章标签 使用 介绍 ios fmdb

本文主要是介绍iOS——FMDB的介绍与使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是FMDB

FMDB是iOS平台用OC语言封装了SQLite API的数据库框架,其优点是:

  • 面向对象,使用了oc语言,避免了和c打交道
  • FMDB是轻量级框架,使用更加灵活、方便
  • 提供了多线程的方式来操作数据库,可以防止多线程操作带来的数据混乱
    FMDB同时兼容ARC和非ARC工程,会自动根据工程配置来调整相关的内存管理代码。

FMDB常用类

FMDatabase:一个FMDatabase对象就代表一个单独的SQLite数据库用来执行SQL语句。
FMResultSet:使用FMDatabase执行查询后的结果集。
FMDatabaseQueue:用于在多线程中执行多个查询或更新,它是线程安全的。

使用方法

  • 首先,我们需要导入FMDB库,和配置JSONModel、Masonry那些的方法一样。
  • FMDB中对数据库中存储的每一个值都有一个类型
    NULL 值为空值
    INTEGER 值被标识为整数,依据值的大小可以依次被存储1~8个字节
    *REAL *所有值都是浮动的数值
    TEXT 值为文本字符串
    BLOB 值为blob数据

NSSearchPathForDirectoriesInDomains方法返回的是一个数组类型的数据,所以这里是获取它返回数组的最后一个元素。
NSSearchPathForDirectoriesInDomains 函数用于获取指定目录的路径。它的参数分别表示:

  1. 目标目录的类型(Search Path Directory Type):这是一个枚举值,用于指定你希望获取的目录的类型。常见的类型包括:

    • NSDocumentDirectory:文档目录,通常用于存储用户生成的文件,例如文档或用户数据。
    • NSLibraryDirectory:库目录,通常用于存储应用程序的支持文件和数据。
    • NSCachesDirectory:缓存目录,通常用于存储可以随时重建的临时文件或缓存数据。
    • NSApplicationSupportDirectory:应用程序支持目录,用于存储应用程序支持的数据文件。
  2. 目标目录的域(Search Path Domain Mask):这是一个枚举值,用于指定搜索目录的域。常见的域包括:

    • NSUserDomainMask:搜索用户的主目录,通常在此域中搜索应用特定的目录。
    • NSLocalDomainMask:搜索本地机器上的目录,通常在此域中搜索系统级的目录。
    • NSNetworkDomainMask:搜索网络上的目录,通常在此域中搜索网络共享目录。
    • NSAllDomainsMask:搜索所有域。
  3. 是否展开波浪符号(Expanding Tilde to Path):这是一个布尔值,如果设置为 YES,则会将波浪符号 (~) 扩展为用户的主目录路径。这通常用于获取用户特定的目录路径。如果设置为 NO,则波浪符号将保持不变。

stringByAppendingPathComponent是路径拼接,会在字符串前自动添加“/”,成为完整路径。

在创建文件的时候,会有几种情况:

  1. 当数据库具体文件路径有效时,正常访问
  2. 当数据库具体文件路径不存在时,自动创建一个该路径的数据库文件
  3. 当数据库具体文件路径为空字符串时(@“”),会在临时目录创建一个空的数据库,当FMDatabase连接关闭时,数据库文件也被删除。
  4. 当数据库具体文件路径为nil,会创建一个内存中临时数据库,当FMDatabase连接关闭时,数据库会被销毁。

CREATE TABLE IF NOT EXISTS collectionData:
意思是你创建了一个叫做collectionData的数据库,自己创建的话也可以改为自己方便识别的名字。
mainLabel text NOT NULL:
意思就是你在刚才的collectionData数据库里边添加了一个text类型的名叫mainLabel的一个索引,其它代码意思也相似。

FMDB的增删改查

以下用代码说明:


#import "test.h"@implementation test- (void)getData {//获取数据库文件路径NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];//stringByAppendingPathComponent拼接路径NSString *fileName = [doc stringByAppendingPathComponent:@"collectionData.sqlite"];NSLog(@"%@", fileName);//获得数据库self.collectionDatabase = [FMDatabase databaseWithPath:fileName];//打开数据库if ([self.collectionDatabase open]) {//创表BOOL result = [self.collectionDatabase executeUpdate:@"CREATE TABLE IF NOT EXISTS collectionData (mainLabel text NOT NULL, nameLabel text NOT NULL, imageURL text NOT NULL, networkURL text NOT NULL, dateLabel text NOT NULL, nowLocation text NOT NULL, goodState text NOT NULL, collectionState text NOT NULL, id text NOT NULL);"];if (result) {NSLog(@"创表成功");} else {NSLog(@"创表失败");}}
}//FMDB的增删改查
//插入数据
- (void)insertData {if ([self.collectionDatabase open]) {NSString *string = @"aaa";//INSERT INTO collectionData意思是向collectionData插入数据,(mainLabel, nameLabel, imageURL, networkURL, dateLabel, nowLocation, goodState, collectionState, id)表示你要赋值的索引,(?, ?, ?, ?, ?, ?, ?, ?, ?);", string, string, string, string, string, string, string, string, string表示你要赋的值BOOL result = [self.collectionDatabase executeUpdate:@"INSERT INTO collectionData (mainLabel, nameLabel, imageURL, networkURL, dateLabel, nowLocation, goodState, collectionState, id) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?);", string, string, string, string, string, string, string, string, string];if (!result) {NSLog(@"增加次数失败");} else {NSLog(@"增加次数成功");}//关闭文件[self.collectionDatabase close];}
}//更新数据
- (void) updateData {if ([self.collectionDatabase open]) {//UPDATE collectionData SET id = ? WHERE nameLabel = ?意思是当nameLabel = ?条件成立的时候,更新collectionData中的id索引对应的数据NSString *sql = @"UPDATE collectionData SET id = ? WHERE nameLabel = ?";BOOL result = [self.collectionDatabase executeUpdate:sql, @"1", @"aaa"];if (!result) {NSLog(@"数据修改失败");} else {NSLog(@"数据修改成功");}[self.collectionDatabase close];}
}//删除数据
- (void)deleteData {if ([self.collectionDatabase open]) {//delete from collectionData WHERE collectionState = ?意思是当collectionState = ?条件成立后删除collectionData数据库中的一组数据NSString *sql = @"delete from collectionData WHERE collectionState = ?";BOOL result = [self.collectionDatabase executeUpdate:sql, @"bbb"];if (!result) {NSLog(@"数据删除失败");} else {NSLog(@"数据删除成功");}[self.collectionDatabase close];}
}- (void)queryData {if ([self.collectionDatabase open]) {//SELECT * FROM collectionData:选择collectionData中的数据,*处也可以改为WHERE条件。FMResultSet *resultSet = [self.collectionDatabase executeQuery:@"SELECT * FROM collectionData"];while ([resultSet next]) {NSString *mainLabel = [resultSet stringForColumn:@"mainLabel"];NSLog(@"mainLabel = %@", mainLabel);}[self.collectionDatabase close];}
}@end
  • 其中,stringForColumn 是 FMDB 库中的一个方法,用于从查询结果集中提取特定列的值,并将其作为字符串返回。这个方法的目的是将数据库中的数据以字符串的形式提取,适用于查询列中包含文本数据的情况。

这篇关于iOS——FMDB的介绍与使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352658

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window