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

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]