SQLiteC/C++接口详细介绍sqlite3_stmt类(十一)

 返回:SQLite—系列文章目录   

上一篇:SQLiteC/C++接口详细介绍sqlite3_stmt类(十)

下一篇: SQLiteC/C++接口详细介绍sqlite3_stmt类(十二)

43、sqlite3_reset

sqlite3_reset 函数用于重置已经编译并执行的 SQL 语句,将该语句恢复到初始状态,以便可以重新绑定参数并再次执行。

函数原型如下:

int sqlite3_reset(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经编译并执行的 SQLite 语句对象。

返回值:

- 返回 `SQLITE_OK` 表示执行成功,否则返回其他错误码。

举例用法:

sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "INSERT INTO user (name, age) VALUES (?, ?)", -1, &stmt, 0);
sqlite3_bind_text(stmt, 1, "张三", -1, SQLITE_STATIC);
sqlite3_bind_int(stmt, 2, 18);
if (sqlite3_step(stmt) != SQLITE_DONE) {// 执行失败
} else {// 执行成功,重置语句以便重新绑定参数并执行sqlite3_reset(stmt);sqlite3_bind_text(stmt, 1, "李四", -1, SQLITE_STATIC);sqlite3_bind_int(stmt, 2, 20);if (sqlite3_step(stmt) != SQLITE_DONE) {// 执行失败}
}

在上面的示例中,我们首先使用 `sqlite3_prepare_v2` 函数编译了一条 SQL 语句,并绑定了两个参数。然后使用 `sqlite3_step` 函数执行该语句,并判断执行结果。如果执行成功,我们调用 `sqlite3_reset` 函数将该语句重置到初始状态,然后重新绑定参数执行。这样就可以重复执行同一段 SQL 语句,并改变绑定参数的值。

44、sqlite3_sql    

sqlite3_sql 函数用于获取已编译的 SQL 语句的原始 SQL 字符串,用于调试和日志记录等场景。

函数原型如下:

const char *sqlite3_sql(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经编译的 SQLite 语句对象。

返回值:

- 返回已经编译的 SQL 语句的原始 SQL 字符串。

举例用法:

sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "SELECT * FROM user WHERE age > ?", -1, &stmt, 0);
sqlite3_bind_int(stmt, 1, 18);
const char *sql = sqlite3_sql(stmt);
printf("SQL statement: %s\n", sql);

在上面的示例中,我们使用 `sqlite3_prepare_v2` 函数编译了一条 SQL 语句,并绑定了一个参数。然后使用 `sqlite3_sql` 函数获取该语句的原始 SQL 字符串,并打印出来。

注意:获取的字符串是编译后的 SQL 语句原始字符串,并未包含实际值或绑定参数的占位符。

 45、sqlite3_step  

sqlite3_step 函数用于逐行执行已编译的 SQL 语句,并返回一行数据或执行结果。

函数原型如下:

int sqlite3_step(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经编译的 SQLite 语句对象。

返回值:

- 返回 `SQLITE_ROW` 表示获取到了一行数据;返回 `SQLITE_DONE` 表示该语句执行结束;返回其他错误码表示执行失败。

举例用法:

sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "SELECT * FROM user WHERE age > ?", -1, &stmt, 0);
sqlite3_bind_int(stmt, 1, 18);
while (sqlite3_step(stmt) == SQLITE_ROW) {int id = sqlite3_column_int(stmt, 0);const unsigned char *name = sqlite3_column_text(stmt, 1);int age = sqlite3_column_int(stmt, 2);printf("id=%d, name=%s, age=%d\n", id, name, age);
}

在上面的示例中,我们使用 `sqlite3_prepare_v2` 函数编译了一条 SQL 语句,并绑定了一个参数。然后使用 `sqlite3_step` 函数逐行获取该语句的结果,并打印出来。

注意:使用 `sqlite3_step` 函数时需要逐行获取结果并进行处理,可以使用 `sqlite3_column_xxx` 系列函数获取单元格中的数据。 

46、sqlite3_stmt_busy      

sqlite3_stmt_busy 函数用于判断指定的 SQLite 语句对象是否正在使用中。

函数原型如下:

int sqlite3_stmt_busy(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经编译的 SQLite 语句对象。

返回值:

- 如果指定的语句对象正在使用中,则返回非零值;否则返回零。

举例用法:

sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "INSERT INTO user (name, age) VALUES (?, ?)", -1, &stmt, 0);
if (sqlite3_stmt_busy(stmt)) {printf("语句对象正在使用中\n");
} else {printf("语句对象未被使用\n");
}
sqlite3_finalize(stmt);

在上面的示例中,我们首先使用 `sqlite3_prepare_v2` 函数编译了一条 SQL 语句,并判断该语句对象是否正在使用中。然后使用 `sqlite3_finalize` 函数销毁语句对象。

这个函数可以用于判断语句对象是否可以被重用,或是在多线程环境下防止同时访问同一语句对象。

47、sqlite3_stmt_explain    

sqlite3_stmt_explain 函数用于生成 SQLite3 的执行计划,并将其以文本格式存储到回调函数中。

函数原型如下:

int sqlite3_stmt_explain(sqlite3_stmt* pStmt,int (*xCallback)(void*,int,const char*,const char*,const char*), void *pArg,int bVerbose
);

参数说明:

- pStmt:已经编译的 SQLite 语句对象。
- xCallback:回调函数指针,用于接收执行计划输出。
- pArg:回调函数的第一个参数,在回调函数中使用。
- bVerbose:是否使用详细模式,1 表示详细模式,0 表示简洁模式。

回调函数的参数说明:

- 第一个参数:回调函数的第二个参数(即 `pArg` 参数)。
- 第二个参数:口令类型,可以是下列字符串中的某一个:
    - `"Trace"`:表示该行是跟踪信息行。
    - `"EXECUTE"`:表示该行是执行计划的一部分。
    - `"SCAN TABLE"`:表示该行是从某个表中扫描行。
    - `"SEARCH TABLE"`:表示该行是在某个表中搜索行。
    - `"SEARCH SUBQUERY"`:表示该行是在子查询中搜索行。
    - `"USE TEMP B-TREE"`:表示该行是使用零时 B-TREE 进行排序或分组。
    - `"USE TEMP INDEX"`:表示该行是使用零时索引进行搜索。
    - `"FIXED COLUMNS"`:表示该行是选择的列中的列,而不是搜索条件中的列。
- 第三个参数:SQL 语句执行计划的深度。
- 第四个参数:与执行计划相关的字符串信息,如关键字、表名、索引等。
- 第五个参数:与执行计划相关的数值信息,如扫描的行数等。

返回值:

- 返回 `SQLITE_OK` 表示执行成功,否则返回其他错误码。

举例用法:

static int explain_callback(void *pArg, int iDepth, const char *zType, const char *zName, const char *zExtra) {printf("%*s%s %s%s\n", iDepth*2, "", zType, zName, (zExtra ? zExtra : ""));return SQLITE_OK;
}
sqlite3_stmt *stmt;
sqlite3_prepare_v2(db, "SELECT * FROM user WHERE age > ?", -1, &stmt, 0);
sqlite3_bind_int(stmt, 1, 18);
sqlite3_stmt_explain(stmt, explain_callback, NULL, 0);
sqlite3_finalize(stmt);

在上面的示例中,我们使用 `sqlite3_prepare_v2` 函数编译了一条 SQL 语句,并绑定了一个参数。然后使用 `sqlite3_stmt_explain` 函数生成执行计划,并将输出以文本格式打印出来。

回调函数 `explain_callback` 的作用是将执行计划文本格式打印在控制台上。可以在回调函数中将文本信息存储到一个文件或内存缓冲区中。

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

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

相关文章

uniapp安装axios

先npm安装 npm i axios然后在项目里面建一个utils文件,再建一个index.js 以下是index.js代码: import axios from axios; const service axios.create({baseURL: //xxxx.xxxxx.com///你的请求接口域名, timeout: 6000, // request timeoutcrossDomai…

【C++】1599. 米老鼠偷糖果

问题:1599. 米老鼠偷糖果 类型:基本运算、整数运算 题目描述: 米老鼠发现了厨房放了 n 颗糖果,它一次可以背走 a 颗,请问米老鼠背了 x 次之后还剩多少颗?(假设 x 次之后一定有糖果剩下&#x…

Redis中的缓存击穿

缓存击穿 缓存击穿问题也叫热点key问题,就是一个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大压力。 🤔现象分析: 当线程1查询缓存时,未命中,于是从数据…

transformer的自注意力模型如何实现自注意力

Transformer | 鲁老师 所有参考来自以上的文章,简单来说,要实现自注意力,就得去完成 自己点乘自己的操作,然后得到的结果就能够通过调整矩阵参数完成训练了。 简单来说,构造了三个矩阵 ,这三个矩阵就是为…

界面控件DevExpress ASP.NET Ribbon组件 - 完美复刻Office 365体验!

无论用户是喜欢传统工具栏菜单外观、样式,还是想在下一个项目中复制Office 365 web UI,DevExpress ASP.NET都提供了所需要的工具,帮助用户打造更好的应用程序界面。 P.S:DevExpress ASP.NET Web Forms Controls拥有针对Web表单&a…

基于python+vue的O2O生鲜食品订购flask-django-nodejs-php

近年来互联网络的迅猛发展和电子终端设备的普及,赋予了各行业充足的发展空间。微信小程序的O2O生鲜食品订购相比于传统信息技术,时效性是它最大的特色,已经在电子娱乐、经济等中发挥着举足轻重的作用。短时间内迅速扩大了线上管理系统的规模。…

【PHP】通过PHP实时监控Apache、MySQL服务运行状态

一、前言 有些时候我们需要监控一些服务的运行状态,比如说Apach或MySQL的运行状态,最近工作中也开发了这方面的功能,记录下来怎样使用PHP语言来实时监控Apache、MySQL服务的运行状态。 如果想一键开启Apache或MySQL等其他服务可以看这篇文章…

CSS color-mix() 函数

CSS color-mix() 函数是近年来CSS色彩模块新增的一项强大功能,允许开发者在样式表中直接混合两种或多种颜色。这一特性为设计师和开发者带来了更多创作空间,让网页的颜色设计变得更加生动和丰富。本文将带你了解 color-mix() 函数的使用方法及其在实际项…

计网--网络层个人笔记

网络层的IP分组由路由器转发,而每一个路由器有很多接口,那么从哪一个接口转发便需要转发表。 一、网络层基本功能 二、SDN基本概念 2.1 路由器 数据平面:转发的过程。一个分组如何从一个端口到达另一个端口。 控制平面:路由选择…

JAVA 8 新特性 Lamdba表达式(二)

一、Lamdba的语法 (参数类型1 参数1,参数类型2 参数2,…) -> { 方法体 }; Lambda表达式就是一个匿名函数,不关注方法名,只关注参数和方法体。 Lambda表达式组成三要素:括号(),箭头->,代码…

ES 8.x的多实例集群搭建与角色规划

ES 8 多实例集群搭建与角色规划 ES 8版本与之前版本存在较大改变,第一个区别就是启动时默认开启了安全模式,也就是即便是测试环境也需要用户名密码和https传输层安全证书。此外,集群节点的角色也与之前不同,除了新增角色外在配置…

Unity 获取鼠标滚轮信息的一些方法

Unity获取鼠标滚轮信息有以下一些方法: 1、使用Input.GetAxis(“Mouse ScrollWheel”)来获取鼠标滚轮的信息,如: //法一:float scrollWheelInput Input.GetAxis("Mouse ScrollWheel");if (scrollWheelInput > 0f){…

机器学习的概念、步骤、分类和实践

作为资深人工智能专家,对机器学习有着深入的研究和实践经验。以下是对机器学习概念、步骤、分类和实践的逐步分析: 一、机器学习概念 机器学习是人工智能的一个子集,它让计算机从数据中学习并改进其性能,而无需进行明确的编程。…

使用专属浏览器在国内直连GPT教程

Wildcard官方推特发文说他们最近推出了一款专门为访问OpenAI设计的浏览器。 根据官方消息,这是一款专门为访问OpenAI优选网络设计的浏览器,它通过为用户提供专用的家庭网络出口,确保了快速、稳定的连接。 用这个浏览器的最大好处就是直接用浏…

【测试开发学习历程】MySQL增删改操作 + 备份与还原 + 索引、视图、存储过程

前言: SQL内容的连载,到这里就是最后一期啦! 如果有小伙伴要其他内容的话,我会追加内容的。(前提是我有学过,或者能学会) 接下来,我们就要开始python内容的学习了 ~ ~ 目录 1 …

Github 2024-03-22 开源项目日报Top10

根据Github Trendings的统计,今日(2024-03-22统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目3C#项目1Java项目1Rust项目1Go项目1Shell项目1非开发语言项目1TypeScript项目1Colossal-AI:使大型人工智能模型更加实惠和快速训练的…

吴恩达机器学习笔记 二十六 决策树学习过程 独热编码one-hot

决策树的学习过程 1. 所有样本都在根结点 2.计算所有可能的特征的信息增益,选择信息增益最大的那个 3.根据选择的特征分离数据集,创造左右两支子树 4.继续进行分裂直到达到停止标准。停止标准有:一个节点只有一类样本;分裂一…

[ABC206E] Divide Both 解题记录

[ABC206E] Divide Both 解题记录 题意简述 给定整数 L , R L,R L,R,求满足以下条件的数对 ( x , y ) (x,y) (x,y) 的数量。 x , y x,y x,y 不互质 x ∤ y x \nmid y x∤y 且 y ∤ x y \nmid x y∤x 题目分析 正难则反,考虑用所有的满足第一条性质的…

javascript中Date相关方法

Date 对象用于处理日期和时间 序号方法描述1new Date()获取当前时间2parse()返回毫秒数(从 1970-1-1 00:00:00开始)3getDate()返回月中的第几天(从 1 到 31)4getFullYear()返回年份5getMonth()返回月份(从 0-11&#x…

1Panel应用推荐:DataEase开源数据可视化分析工具

1Panel(github.com/1Panel-dev/1Panel)是一款现代化、开源的Linux服务器运维管理面板,它致力于通过开源的方式,帮助用户简化建站与运维管理流程。为了方便广大用户快捷安装部署相关软件应用,1Panel特别开通应用商店&am…