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

相关文章

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数