装饰公司网站建设/商城全网推广运营公司
第一节:数据库
常见的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 tablesqlite3_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
相关文章:

ios 之 数据库、地理位置、应用内跳转、推送、制作静态库、CoreData
第一节:数据库 常见的API SQLite提供了一系列的API函数,用于执行各种数据库相关的操作。以下是一些常用的SQLite API函数及其简要说明:1. sqlite3_initialize:- 初始化SQLite库。通常在开始使用SQLite之前调用,但如果没有调用&a…...

Django(三)
1.快速上手 确保app已注册 【settings.py】 编写URL和视图函数对应关系 【urls.py】 编写视图函数 【views.py】 启动django项目 命令行启动python manage.py runserverPycharm启动 1.1 再写一个页面 2. templates模板 2.1 静态文件 2.1.1 static目录 2.1.2 引用静态…...

vscode括号颜色突然变成白色的了,怎么解决
更新版本后发现vscode的各种括号都变成了白色,由于分色括号已经使用习惯,突然变成白色非常不舒服,尝试多次后,为大家提供一下几种解决方式,希望能帮到同样受到此种困惑的你: 第一种: 首先打开…...

测试服务器带宽(ubuntu)
apt install python3 python3-pippip3 install speedtest-clispeestest-cli...

【WPF】使用Behavior以及ValidationRule实现表单校验
文章目录 使用ValidationRule实现检测用户输入EmptyValidationRule 非空校验TextBox设置非空校验TextBox设置非空校验并显示校验提示 结语 使用ValidationRule实现检测用户输入 EmptyValidationRule是TextBox内容是否为空校验,TextBox的Binding属性设置ValidationRu…...

ArcGIS渔网的多种用法
在ArcGIS中有一个渔网工具,顾名思义,可以用来创建包含由矩形像元所组成网络的要素类。不太起眼,但它的用途却有很多,今天跟大家分享一篇关于渔网的多种用途。 1.马赛克地图制作 2.基于网格的设施密度统计制作马赛克地图 准备材…...

C++ 中使用 std::map 的一个示例
std::map 是一个容器,可以用来存储键值对,其中键是唯一的,每个键都映射到一个值 #include <iostream> #include <map>int main() {// 声明了一个 std::map<std::string, int> 类型的变量 myMap,它可以将字符串…...

python虚拟环境及其在项目实践中的应用
文章目录 1.问题的提出1.什么是python虚拟环境2.如何创建2.1第1步-为共享同一虚拟环境的项目创建共同的父目录2.2第2步-在父目录下创建虚拟python环境2.3在父目录下创建各个项目文件夹 1.问题的提出 假设我正在开发若干python项目,这里假定项目名分别为Project1&am…...

普中STM32-PZ6806L开发板(烧录方式)
前言 有两种方式, 串口烧录和STLink方式烧录;串口烧录 步骤 开发板USB转串口CH340驱动板接线到USB连接PC使用自带工具普中自动下载软件.exe烧录程序到开发板 ST Link方式 这种方式需要另外进行供电, 我买的如下,当年用于调试STM8的,也可…...

基于单片机设计的指纹锁(读取、录入、验证指纹)
一、前言 指纹识别技术是一种常见的生物识别技术,利用每个人指纹的唯一性进行身份认证。相比于传统的密码锁或者钥匙锁,指纹锁具有更高的安全性和便利性,以及防止钥匙丢失或密码泄露的优势。 基于单片机设计的指纹锁项目是利用STC89C52作为…...

HarmonyOS - 基础组件绘制
文章目录 所有组件开发 tipsBlankTextImageTextInputButtonLoadingProgress 本文改编自:<HarmonyOS第一课>从简单的页面开始 https://developer.huawei.com/consumer/cn/training/course/slightMooc/C101667360160710997 所有组件 在 macOS 上,组…...

AR智慧校园三维主电子沙盘系统研究及应用
一 、概述 易图讯科技(www.3dgis.top)自主研发的智慧校园三维主电子沙盘系统,采用B/S架构模式,采用自主可控高性能WebGIS可视化引擎,支持多用户客户端通过网络请求访问服务器地图和专题数据,提供地理信息数据、专题数据的并发访问…...

web前端项目-七彩夜空烟花【附源码】
web前端项目-七彩动态夜空烟花【附源码】 本项目仅使用了HTML,代码简单,实现效果绚丽,且本项目代码直接运行即可实现,无需图片素材,接下来让我们一起实现一场美丽的烟花秀叭 运行效果:鼠标点击和移动可控制…...

在k8s中将gitlab-runner的运行pod调度到指定节点
本篇和前面的 基于helm的方式在k8s集群中部署gitlab 具有很强的关联性,因此如果有不明白的地方可以查看往期分享: 基于helm的方式在k8s集群中部署gitlab - 部署基于helm的方式在k8s集群中部署gitlab - 备份恢复基于helm的方式在k8s集群中部署gitlab - 升…...

1.解决父组件传数据给子组件太慢,导致子组件获取不到合适数据渲染出错问题2.vue中props传递异步数据,子组件用watch监听
vue中props传递异步数据,子组件用watch监听...

SpringMVC之获取请求参数和域对象共享数据
学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您: 想系统/深入学习某技术知识点… 一个人摸索学习很难坚持,想组团高效学习… 想写博客但无从下手,急需…...

IntelliJ IDEA Community(社区版)下载及安装自用版
IntelliJ IDEA Community(社区版)下载及安装自用版 估计是个开发都逃脱不了用IDEA的命运吧,这么好的软件,白嫖了好多年。感恩。 现在很多公司已经不让用商业版的破解版了,所以这里讲的是社区版。 区别: 商…...

【C语言:编译、预处理详解】
文章目录 1.编译2.预处理2.1宏定义2.1.1预定义符号2.1.2#define定义常量2.1.3#define定义宏2.1.4do-while-zero2.1.5宏的注意事项2.1.6宏与函数的对比 2.2条件编译2.3文件包含 3.offsetoff4.#与##4.1. #号4.2 ##号 1.编译 我们都知道,一个程序如果想运行起来要经过…...

【宇宙猜想】AR文创入驻今日美术馆、北京天文馆等众多展馆,在AR互动中感受科技魅力!
近日,由「宇宙猜想」推出的AR系列文创产品先后入驻今日美术馆、北京天文馆、国家自然博物馆、上海天文馆、国家海洋馆、中华手工展馆等各大馆场并与其展开相关合作。 「宇宙猜想」致力于创造虚拟空间价值,用AR技术与文创产品碰撞出新的火花,为…...

前端面试题html
HTML DOCTYPE有什么作用? DOCTYPE是一种指示浏览器以何种HTML或XHTML规范来解析文档的声明。它能够告知浏览器网页文档使用的标记语言的类型以及版本,从而确保浏览器能够正确地展示网页内容。DOCTYPE声明通常位于HTML文档的开头,是HTML文档…...

AOSP源码下载方法,解决repo sync错误:android-13.0.0_r82
篇头 最近写文章,反复多次折腾AOSP代码,因通过网络repo sync aosp代码,能一次顺利下载的概率很低,以前就经常遇到,但从未总结,导致自己也要回头检索方法,所以觉得可以总结一下,涉及…...

TCP:IP原理
TCP/IP 原理 TCP/IP 协议不是 TCP 和 IP 这两个协议的合称,而是指因特网整个 TCP/IP 协议族。从协议分层模型方面来讲,TCP/IP 由四个层次组成:网络接口层、网络层、传输层、应用层。 网络访问层(Network Access Layer) 网络访问层(Network …...

Java 中 Lambda 表达式的使用
目录 一、Lambda 表达式的概念 二、Lambda 表达式的语法格式 三、Lambda 表达式的案例使用 1、使用 Lambda 来实现启动线程 2、使用 Lambda 表达式实现集合的排序 3、使用 Lambda 表达式实现文件夹下的文件查找 一、Lambda 表达式的概念 Lambda 表达式是特殊的匿名内部类…...

【IO】IO模型与零拷贝
前言: 正在运行的程序其实就是系统中的一个进程,操作系统会为每一个进程分配内存空间,而内存空间分为两部分,一部分是用户空间,这是用户进程访问的内存区域;另一部分是内核空间,是操作系统内核访…...

鸿蒙 - arkTs:状态管理
状态 State: 在声明式UI中,以状态驱动视图更新 状态(State):指驱动视图更新的数据(被装饰器标记的变量)视图(View):基于UI描述渲染得到的用户界面 使用示例…...

YOLOv5-Lite 树莓派4B 15帧教程
【前言】 由于v5Lite仓库遗漏了不少历史问题,最大的问题是毕业后卷起来了,找不到时间更新。 上面是这篇博客的背景,那么先说下结论,使用 v5lite-e 模型,在 树莓派4B(4G内存) 上,有三…...

2014年第三届数学建模国际赛小美赛A题吹口哨解题全过程文档及程序
2014年第三届数学建模国际赛小美赛 A题 吹口哨 原题再现: 哨子是一种小装置,当空气被迫通过开口时会发出声音。哨声的巨大而引人注目,使其对警察和体育裁判来说至关重要。当救生员、迷路的露营者或犯罪受害者使用它们时,它们可以…...

设计模式-注册模式
设计模式专栏 模式介绍模式特点应用场景注册模式和单例模式的区别代码示例Java实现注册模式Python实现注册模式 注册模式在spring中的应用 模式介绍 注册模式是一种设计模式,也称为注册树或注册器模式。这种模式将类的实例化和创建分离开来,避免在应用程…...

css 美化滚动条样式
ChatgGPT4.0国内站点: 海鲸AI-支持GPT(3.5/4.0),文件分析,AI绘图 在CSS中,你可以使用伪元素::-webkit-scrollbar以及相关的伪元素来为Webkit浏览器(如Chrome和Safari)自定义滚动条的样式。以下是一些基本的CSS规则&am…...

视频压缩不影响画质简单方法,一分钟搞定!
很多朋友在处理视频的时候都会遇到视频过大的问题,想要压缩视频的同时不影响画质,简单的方法有两种。一种是用专业的压缩软件,在压缩的时候设置一个合适的压缩比例,压缩大小的同时保持清晰度,也能提高压缩率࿰…...