ios 之 数据库、地理位置、应用内跳转、推送、制作静态库、CoreData

news2025/2/8 21:01:22

第一节:数据库
常见的API
SQLite提供了一系列的API函数,用于执行各种数据库相关的操作。以下是一些常用的SQLite API函数及其简要说明:

1. `sqlite3_initialize`:
   - 初始化SQLite库。通常在开始使用SQLite之前调用,但如果没有调用,SQLite会在第一次需要时自动调用。

2. `sqlite3_shutdown`:
   - 清理SQLite库。在不再需要SQLite库时调用,用于释放所有由SQLite分配的资源。

3. `sqlite3_open`:
   - 打开一个新的数据库连接。如果指定的文件不存在,SQLite会尝试创建一个新的数据库文件。

4. `sqlite3_open_v2`:
   - 打开一个新的数据库连接,提供更多的控制选项,如只读打开、创建数据库文件等。

5. `sqlite3_close`:
   - 关闭一个打开的数据库连接。如果有未完成的准备语句或未关闭的BLOB句柄,会返回`SQLITE_BUSY`。

6. `sqlite3_close_v2`:
   - 关闭一个打开的数据库连接,但允许延迟关闭直到所有关联的语句和BLOB句柄都被关闭。

7. `sqlite3_exec`:
   - 执行一个SQL语句,并不返回查询结果。适用于执行INSERT、UPDATE、DELETE等操作。

8. `sqlite3_prepare_v2`:
   - 将SQL语句编译成一个准备语句(prepared statement),用于后续的绑定参数、执行和获取结果。

9. `sqlite3_step`:
   - 执行或推进一个准备语句。对于查询语句,它会返回`SQLITE_ROW`直到没有更多的数据。

10. `sqlite3_finalize`:
    - 销毁一个准备语句,释放与之相关的资源。

11. `sqlite3_bind_*`:
    - 一系列函数,用于将值绑定到准备语句的参数上。例如`sqlite3_bind_int`、`sqlite3_bind_text`等。

12. `sqlite3_column_*`:
    - 一系列函数,用于从执行结果中提取数据。例如`sqlite3_column_int`、`sqlite3_column_text`等。

13. `sqlite3_changes`:
    - 返回最近一次INSERT、UPDATE或DELETE操作所影响的行数。

14. `sqlite3_last_insert_rowid`:
    - 返回最后一次INSERT操作插入行的ROWID。

15. `sqlite3_errmsg`:
    - 返回最近一次SQLite操作的错误信息。

16. `sqlite3_busy_timeout`:
    - 设置当数据库被锁定时等待解锁的最长时间。

17. `sqlite3_backup_init`:
    - 初始化一个新的数据库备份操作。

18. `sqlite3_backup_step`:
    - 将数据从一个数据库传输到另一个数据库。

19. `sqlite3_backup_finish`:
    - 完成备份操作并释放所有相关资源。

20. `sqlite3_randomness`:
    - 用于填充缓冲区,生成一些随机数据。

21. `sqlite3_config`:
    - 用于配置SQLite的全局行为。

22. `sqlite3_db_config`:
    - 用于配置特定数据库连接的行为。

这些函数只是SQLite提供的众多API中的一部分。SQLite的API设计用于提供灵活性和控制,以满足不同应用程序的需求。在使用这些API时,应该注意正确处理错误代码,并在适当的时候释放资源,以避免内存泄漏或其他问题。
sqlite3_column* 的一些api
1. `sqlite3_column_blob`:
   - 用途:提取类型为BLOB(二进制大对象)的列数据。
   - 返回值:返回指向包含BLOB数据的缓冲区的指针。

2. `sqlite3_column_bytes`:
   - 用途:获取一个列数据的字节数。
   - 返回值:返回列数据的字节数。

3. `sqlite3_column_double`:
   - 用途:提取类型为浮点数的列数据。
   - 返回值:返回列数据的`double`类型值。

4. `sqlite3_column_int64`:
   - 用途:提取类型为64位整数的列数据。
   - 返回值:返回列数据的`sqlite3_int64`类型值。

5. `sqlite3_column_text16`:
   - 用途:提取类型为文本的列数据,返回的是UTF-16编码的文本。
   - 返回值:返回指向包含文本数据的缓冲区的指针。

6. `sqlite3_column_value`:
   - 用途:提取列数据,返回一个`sqlite3_value`类型的对象,可以用来进一步提取不同类型的数据或进行类型转换。
   - 返回值:返回`sqlite3_value`对象的指针。

7. `sqlite3_column_type`:
   - 用途:获取列数据的数据类型。
   - 返回值:返回一个整数,表示数据类型,如`SQLITE_INTEGER`、`SQLITE_FLOAT`、`SQLITE_TEXT`、`SQLITE_BLOB`或`SQLITE_NULL`。

这些函数通常在调用`sqlite3_step`函数后,且其返回值为`SQLITE_ROW`时使用,以从当前的查询结果中提取数据。使用这些函数时,需要传入准备好的语句对象(`sqlite3_stmt *`)和列的索引(从0开始)。根据列中存储的数据类型选择合适的`sqlite3_column_*`函数来获取数据。

1. `sqlite3_column_blob`:
   - 用途:提取类型为BLOB(二进制大对象)的列数据。
   - 返回值:返回指向包含BLOB数据的缓冲区的指针。

2. `sqlite3_column_bytes`:
   - 用途:获取一个列数据的字节数。
   - 返回值:返回列数据的字节数。

3. `sqlite3_column_double`:
   - 用途:提取类型为浮点数的列数据。
   - 返回值:返回列数据的`double`类型值。

4. `sqlite3_column_int64`:
   - 用途:提取类型为64位整数的列数据。
   - 返回值:返回列数据的`sqlite3_int64`类型值。

5. `sqlite3_column_text16`:
   - 用途:提取类型为文本的列数据,返回的是UTF-16编码的文本。
   - 返回值:返回指向包含文本数据的缓冲区的指针。

6. `sqlite3_column_value`:
   - 用途:提取列数据,返回一个`sqlite3_value`类型的对象,可以用来进一步提取不同类型的数据或进行类型转换。
   - 返回值:返回`sqlite3_value`对象的指针。

7. `sqlite3_column_type`:
   - 用途:获取列数据的数据类型。
   - 返回值:返回一个整数,表示数据类型,如`SQLITE_INTEGER`、`SQLITE_FLOAT`、`SQLITE_TEXT`、`SQLITE_BLOB`或`SQLITE_NULL`。

这些函数通常在调用`sqlite3_step`函数后,且其返回值为`SQLITE_ROW`时使用,以从当前的查询结果中提取数据。使用这些函数时,需要传入准备好的语句对象(`sqlite3_stmt *`)和列的索引(从0开始)。根据列中存储的数据类型选择合适的`sqlite3_column_*`函数来获取数据。
sqlite 中key值的类型
SQLite支持以下几种基本的数据类型(也称为存储类):

1. `NULL`:
   - 用于存储NULL值,表示该值是一个空值。

2. `INTEGER`:
   - 用于存储整数。根据数值的大小,可以使用1、2、3、4、6或8字节存储。

3. `REAL`:
   - 用于存储浮点数。通常是8字节的IEEE浮点数。

4. `TEXT`:
   - 用于存储文本字符串。SQLite使用数据库编码(UTF-8、UTF-16BE或UTF-16LE)来存储文本。

5. `BLOB`:
   - 用于存储二进制大对象(Binary Large OBject)。BLOB类型的数据完全按照输入存储,不做任何转换。

除了这些基本类型,SQLite还有一个特殊的数据类型:

6. `NUMERIC`:
   - 这不是一个独立的数据类型,而是一个类型亲和性(type affinity)。在SQLite中,表的列可以被指定为NUMERIC亲和性,这意味着SQLite会根据存储的数据尝试使用INTEGER或REAL类型,如果这两种类型都不适合,它会将数据存储为TEXT。

SQLite的类型系统比较灵活,它使用动态类型,不强制数据类型。这意味着你可以在任何列中存储任何类型的数据,不过SQLite会根据列的声明类型(亲和性)尝试进行一些优化。例如,如果你声明一个列为INTEGER类型,SQLite会尽可能将存储在该列中的数据作为整数来处理
示例:用一个数据库文件来保存数据
1. 导入SQLite库:
   在你的Xcode项目中,你需要链接`libsqlite3.tbd`(或`libsqlite3.dylib`)库。
   你可以在项目的"Build Phases" -> "Link Binary With Libraries"中添加这个库。

2. 导入头文件:
   在你的Objective-C类中,导入SQLite的头文件:
   
   #import <sqlite3.h>


3. 打开数据库:
   使用`sqlite3_open`函数来打开一个数据库。如果数据库文件不存在,
   SQLite会尝试创建一个新的数据库。

   sqlite3 *database;
   NSString *dbPath = @"path_to_your_database_file.db";

   if (sqlite3_initialize() != SQLITE_OK) {
       //未初始化
   }

   if (sqlite3_open([dbPath UTF8String], &database) == SQLITE_OK) {
       // Database opened successfully
   } else {
       // Failed to open database
   }
   

4. 执行SQL语句:
   你可以使用`sqlite3_exec`来执行SQL语句,例如创建表、插入数据等。
   
   const char *createTableSQL ="CREATE TABLE IF NOT EXISTS People (ID INTEGER PRIMARY KEY AUTOINCREMENT, Name TEXT)";
   char *error;
   if (sqlite3_exec(database, createTableSQL, NULL, NULL, &error) == SQLITE_OK) {
       // Table created successfully
   } else {
       // Failed to create table
       sqlite3_free(error);
   }
  

5. 查询数据:
   使用`sqlite3_prepare_v2`,`sqlite3_step`和`sqlite3_finalize`来查询数据。
   
   const char *querySQL = "SELECT ID, Name FROM People";
   sqlite3_stmt *statement;
   if (sqlite3_prepare_v2(database, querySQL, -1, &statement, NULL) == SQLITE_OK) {
       while (sqlite3_step(statement) == SQLITE_ROW) {
           int personID = sqlite3_column_int(statement, 0);
           const unsigned char *name = sqlite3_column_text(statement, 1);
           NSLog(@"Person ID: %d, Name: %s", personID, name);
       }
       sqlite3_finalize(statement);
   } else {
       // Failed to execute query
   }
   

6. 关闭数据库:
   完成数据库操作后,使用`sqlite3_close`关闭数据库。
   
   sqlite3_close(database);


-------------示例里的一些api的解释----------------

1. `sqlite3_open`
   - **作用**: 打开一个数据库连接,如果数据库文件不存在还可以选择创建数据库。
   - **参数**: 
     - 第一个参数是要打开的数据库文件的路径(使用UTF-8字符串)。
     - 第二个参数是指向`sqlite3`指针的指针,它将被赋予数据库连接的句柄。
   - **返回值**: 返回`SQLITE_OK`(0)表示成功,或者一个错误代码表示失败。

2. `sqlite3_exec`
   - **作用**: 执行无返回结果的SQL语句,如创建表、插入、更新、删除等操作。
   - **参数**:
     - 第一个参数是`sqlite3`数据库连接句柄。
     - 第二个参数是要执行的SQL语句字符串。
     - 第三个参数是处理查询结果的回调函数,这里未用到设置为NULL。
     - 第四个参数是提供给回调函数的参数,这里未用到设置为NULL。
     - 第五个参数是错误信息的指针,当SQL语句执行出错将赋予指向动态分配错误描述文字的指针。
   - **返回值**: 返回`SQLITE_OK`(0)表示成功,或者一个错误代码表示失败。如果失败,错误信息将被写入第五个参数。

3. `sqlite3_prepare_v2`
   - **作用**: 将一个SQL语句编译成一个准备语句(prepared statement),并执行直到第一次`sqlite3_step`调用必需的准备。
   - **参数**:
     - 第一个参数是`sqlite3`数据库连接句柄。
     - 第二个参数是要执行的SQL查询字符串。
     - 第三个参数是SQL语句的长度(传入-1代表系统会根据SQL字符串自动计算长度)。
     - 第四个参数是路径到`sqlite3_stmt`的指针,最终它会指向准备情况(预编译的语句)。
     - 第五个参数是无视的,通常设置为NULL。
   - **返回值**: 返回`SQLITE_OK`表示成功创建,或者错误代码代表其他结果。

4. `sqlite3_step`
   - **作用**: 通过一个准备好的语句进行单步执行。可从查询中提取数据或者执行一个非查询的SQL命令。
   - **参数**:
     - 唯一的参数是编译好的`sqlite3_stmt`语句句柄。
   - **返回值**: 如果是查询并且有更多的数据,返回`SQLITE_ROW`。如果执行完成,返回`SQLITE_DONE`。如果有错误,返回相应的错误码。

5. `sqlite3_column_int`, `sqlite3_column_text`
   - **作用**: 从执行结果中取值。`sqlite3_column_int`用于获取int类型的列数据,`sqlite3_column_text`用于获取文本(字符串)数据。
   - **参数**:
     - 第一个参数是`sqlite3_stmt`对象。
     - 第二个参数是你想要获取的列的索引,从0开始。
   - **返回值**: 返回执行结果中根据索引查找到的相应类型的数据。

6. `sqlite3_finalize`
   - **作用**: 删除(释放)一个`sqlite3_stmt`对象。
   - **参数**:
     - 唯一参数就是被释放的`sqlite3_stmt`对象。
   - **返回值**: 如果成功释放,返回`SQLITE_OK`,失败则返回对应的错误码。

7. `sqlite3_close`
   - **作用**: 关闭一个打开的数据库连接。
   - **参数**:
     - 参数是待关闭的`sqlite3`数据库连接句柄对象。
   - **返回值**: 成功返回`SQLITE_OK`,如果有运行的`sqlite3_stmt`仍未完结,则返回`SQLITE_BUSY`等错误码。

8. `sqlite3_free`
   - **作用**: 用于释放由 SQLite 分配给错误信息字符串的内存的函数。当你使用 `sqlite3_exec` 
     - 或其他需要错误信息的 SQLite 函数时,如果发生错误,SQLite 会分配一块内存来存储错误描述的 
       字符串,并通过函数的参数返回这个字符串的地址。
     - 使用 `sqlite3_free` 函数来释放这块内存是很重要的,因为如果不释放,就会造成内存泄漏。这 
       是因为 SQLite 使用自己的内存分配器来分配和释放内存,所以你需要使用 SQLite 提供的函数来 
       释放由 SQLite 分配的内存
9. `sqlite3_bind_text`
   - **作用**: 用于将一个字符串值绑定到预备(prepared)语句的占位符(也称作绑定变量)上。预备 
              语句是数据库查询语言的一种,通常用于执行参数化查询,以增强安全性并提供对类似查询 
              重复执行的优化
   - 使用
     1. 首先,创建一个预备语句。
     2. 然后,使用 `sqlite3_bind_text` 函数将具体的文本值(如字符串)绑定到这个预备语句的一 
        个占位符上。
     3. 此占位符通常以问号(`?`)表示或使用具名参数占位符(如 `:name`)。
     4. 继续为预备语句的其他占位符(如果有的话)绑定适当的值。
     5. 最后,执行预备语句来对数据库进行查询或者更新。

第二节:定位地理位置
CoreLocation

获取两个经纬度之间的距离

 

地理位置反编码

第三节:MapKit


 

放大、缩小地图

 

添加大头针

 

导航

 

显示导航线

 

第四节:应用间的跳转

通过获取plist 文件中的URL Type ,来动态的获取URL Scheme 

第五节:推送

本地推送

发送通知前要先注册通知

本地通知期间kill调App,通过点击通知横幅,执行对应的操作

设置category

 

判断App是否在前台

远程推送

 ​​​​​​​

程序刚启动时收到的推送

 

第六节:静态库

编译不同的架构

库的资源文件

边开发边调试

创建两个target,一个是app,一个是动态库/静态库,如果想使用静态库的方法,需要导入该文件

framework

第七节:CoreData

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1336011.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

云计算:现代技术的基本要素

众所周知&#xff0c;在儿童教育的早期阶段&#xff0c;幼儿园都会传授塑造未来行为的一些基本准则。 今天&#xff0c;我们可以以类似的方式思考云计算&#xff1a;它已成为现代技术架构中的基本元素。云现在在数字交互、安全和基础设施开发中发挥着关键作用。云不仅仅是另一…

在Android中使用Flow获取网络连接信息

在Android中使用Flow获取网络连接信息 如果你是一名Android开发者&#xff0c;你可能会对这个主题感到有趣。考虑到几乎每个应用程序都需要数据交换&#xff0c;例如刷新动态或上传/下载内容。而互联网连接对此至关重要。但是&#xff0c;当用户的设备离线时&#xff0c;数据如…

Flink电商实时数仓(六)

交易域支付成功事务事实表 从topic_db业务数据中筛选支付成功的数据从dwd_trade_order_detail主题中读取订单事实数据、LookUp字典表关联三张表形成支付成功宽表写入 Kafka 支付成功主题 执行步骤 设置ttl&#xff0c;通过Interval join实现左右流的状态管理获取下单明细数据…

OGG-MySQL无法正常同步数据问题分析

问题背景: 用户通过OGG从源端一个MySQL从库将数据同步到目标端的另一个MySQL数据库里面&#xff0c;后面由于源端的从库出现了长时间的同步延时&#xff0c;由于延时差距过大最后选择通过重建从库方式进行了修复 从库重建之后&#xff0c;源端的OGG出现了报错ERROR OGG-0014…

电商数据分析-02-电商业务介绍及表结构

参考 电商业务简介 大数据项目之电商数仓、电商业务简介、电商业务流程、电商常识、业务数据介绍、电商业务表、后台管理系统 举个例子:&#x1f330; 1.1 电商业务流程 电商的业务流程可以以一个普通用户的浏览足迹为例进行说明&#xff0c;用户点开电商首页开始浏览&…

蓝桥杯备赛 day 1 —— 递归 、递归、枚举算法(C/C++,零基础,配图)

目录 &#x1f308;前言 &#x1f4c1; 枚举的概念 &#x1f4c1;递归的概念 例题&#xff1a; 1. 递归实现指数型枚举 2. 递归实现排列型枚举 3. 递归实现组合型枚举 &#x1f4c1; 递推的概念 例题&#xff1a; 斐波那契数列 &#x1f4c1;习题 1. 带分数 2. 反硬币 3. 费解的…

小程序面试题 | 18.精选小程序面试题

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

大师计划1.0 - log2 CRTO笔记

CRTOⅠ笔记 log2 这个笔记是我在2023年11月23日-12月22日中&#xff0c;学习CRTO所做的一些笔记。 事实上TryHackMe的路径和htb学院包含了许多CRTO的知识并且甚至还超出了CRTO&#xff08;CS除外&#xff09;&#xff0c;所以很多东西在THM和htb学院学过&#xff0c;这次CRTO等…

RK3588平台开发系列讲解(AI 篇)RKNN rknn_query函数详细说明

文章目录 一、查询 SDK 版本二、查询输入输出 tensor 个数三、查询输入 tensor 属性(用于通用 API 接口)四、查询输出 tensor 属性(用于通用 API 接口)五、查询模型推理的逐层耗时六、查询模型推理的总耗时七、查询模型的内存占用情况八、查询模型里用户自定义字符串九、查询原…

往年面试精选题目(前50道)

常用的集合和区别&#xff0c;list和set区别 Map&#xff1a;key-value键值对&#xff0c;常见的有&#xff1a;HashMap、Hashtable、ConcurrentHashMap以及TreeMap等。Map不能包含重复的key&#xff0c;但是可以包含相同的value。 Set&#xff1a;不包含重复元素的集合&#…

第四周:机器学习知识点回顾

前言&#xff1a; 讲真&#xff0c;复习这块我是比较头大的&#xff0c;之前的线代、高数、概率论、西瓜书、樱花书、NG的系列课程、李宏毅李沐等等等等…那可是花了三年学习佳实践下来的&#xff0c;现在一想脑子里就剩下几个名词就觉得废柴一个了&#xff0c;朋友们有没有同感…

Linux操作系统基础知识点

Linux是一种计算机操作系统&#xff0c;其内核由林纳斯本纳第克特托瓦兹&#xff08;Linus Benedict Torvalds&#xff09;于1991年首次发布。Linux操作系统通常与GNU套件一起使用&#xff0c;因此也被称为GNU/Linux。它是一种类UNIX的操作系统&#xff0c;设计为多用户、多任务…

滤波器(Filter)

滤波器 常用滤波器元器件 馈通电容滤波器NFM18PC104R1C3 \SDCW2012-2-900TF \ 0603 0.1UF(104) 16V 文章目录 滤波器前言一、滤波器是什么二、两路 0805共模滤波器 阻抗90Ω@100MHz三、0603 0.1UF(104) 16V四、馈通电容滤波器NFM18PC104R1C3总结前言 滤波器在电子系统中具有…

车载网络 - BootLoader - UDS刷写闲聊

聊升级的话,我们不得不聊一下MCU升级的一些基础概念;我们今天就简单说下,如果大家有兴趣,可以评论区留言,我后续继续补充内容或者私聊都可以的。 目录 一、MCU内存说明 二、常见的2类BOOT段 三、常见的APP段

机器人制作开源方案 | 森林管理员

​作者&#xff1a;李佳骏、常睿康、张智斌、李世斌、高华耸 单位&#xff1a;山西能源学院 指导老师&#xff1a;赵浩成、郜敏 1. 研究背景 森林作为地球上可再生自然资源及陆地生态的主体&#xff0c;在人类生存和发展的历史中起着不可代替的作用&#xff0c;它不仅能提供…

比宜德停业,奥乐齐死磕,硬折扣该怎样长硬不衰?

作者 | 楚文龙 来源 | 洞见新研社 刚刚过去的周末&#xff0c;让零售行业的从业者神经紧绷。因为&#xff0c;12月23日多个信源曝出&#xff0c;社区硬折扣超市比宜德已公告于12月22日起暂停营业。 作为中国第一家&#xff0c;也是唯一一家规模最大的硬折扣社区连锁店零售商&…

FLStudio21中文版水果编曲软件好用吗?如何下载最新版本

FL Studio21版是一款在国内非常受欢迎的多功能音频处理软件&#xff0c;我们可以通过这款软件来对多种不同格式的音频文件来进行编辑处理。而且FL Studio 21版还为用户们准备了超多的音乐乐器伴奏&#xff0c;我们可以直接一键调取自己需要的音调。 FL Studio21版不仅拥有非常…

leetcode——打家劫舍问题汇总

本章汇总一下leetcode中的打家劫舍问题&#xff0c;使用经典动态规划算法求解。 1、梦开始的地方——打家劫舍&#xff08;★&#xff09; 本题关键点就是不能在相邻房屋偷东西。 采用常规动态规划做法&#xff1a; 根据题意设定dp数组&#xff0c;dp[i]的含义为&#xff1a…

【WPF.NET开发】创建样式

本文内容 创建样式隐式应用样式显式应用样式以编程方式应用样式扩展样式TargetType 属性与 x:Key 属性之间的关系 使用 Windows Presentation Foundation (WPF)&#xff0c;可以使用自己的可重用样式自定义现有控件的外观。 可以对应用、窗口和页面全局应用样式&#xff0c;也…

【自定义磨砂动态背景】前端及pyqt6实现

如何实现一个自定义的磨砂动态背景呢&#xff1f; 这种效果看起来特别的高端&#xff0c;很新颖美观。 具体的效果可以看这里的演示&#xff1a;https://www.bilibili.com/video/BV1zj411H7wd/ 其实原理就是底层有多个多彩多边形在移动&#xff0c;然后再盖上一层模糊滤镜。 前…