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

  返回:SQLite—系列文章目录   

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

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

38、sqlite3_column_value      

sqlite3_column_value 函数用于获取指定列的值,并以 sqlite3_value 类型返回。

函数原行:

sqlite3_value *sqlite3_column_value(sqlite3_stmt *pStmt, int iCol);

参数说明:

- pStmt:已经通过 `sqlite3_prepare_v2` 编译过的 SQLite 语句。
- iCol:需要获取值的列索引,从 0 开始编号。

返回值:

- 返回指定列的值,并以 sqlite3_value 类型返回。

该函数可能返回不同类型的值,包括 INTEGER、FLOAT、TEXT、BLOB 和 NULL。

以下是一个示例:

sqlite3_stmt *statement;
sqlite3_prepare_v2(db, "SELECT * FROM users WHERE id=?", -1, &statement, NULL);
sqlite3_bind_int(statement, 1, 1);
int columnCount = sqlite3_column_count(statement);
for (int i = 0; i < columnCount; i++) {
    const char *name = sqlite3_column_name(statement, i);
    sqlite3_value *value = sqlite3_column_value(statement, i);
    int valueType = sqlite3_value_type(value);
    printf("%s: ", name);
    if (valueType == SQLITE_INTEGER) {
        printf("%d\n", sqlite3_value_int(value));
    } else if (valueType == SQLITE_FLOAT) {
        printf("%f\n", sqlite3_value_double(value));
    } else if (valueType == SQLITE_TEXT) {
        printf("%s\n", sqlite3_value_text(value));
    } else if (valueType == SQLITE_BLOB) {
        printf("%d bytes\n", sqlite3_value_bytes(value));
    } else if (valueType == SQLITE_NULL) {
        printf("NULL\n");
    }
}
sqlite3_finalize(statement);

在上面的示例中,我们先使用 sqlite3_prepare_v2 函数准备 SQL 语句,并绑定一个参数。然后使用 sqlite3_column_value 函数获取每个列的值,并根据值的类型打印出来。

注意:使用 sqlite3_value_int 和 sqlite3_value_text 函数获取值时需要根据值的类型进行转换。此外,使用 sqlite3_value_bytes 函数获取 BLOB 类型的值的长度。

39、sqlite3_data_count  

sqlite3_data_count 函数用于获取 SQL 语句执行后返回的列数,用于判断查询结果集中是否有数据。

int sqlite3_data_count(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经通过 `sqlite3_prepare_v2` 编译过的 SQLite 语句。

返回值:

- 返回 SQL 语句执行后返回的结果集中的列数。

以下是一个示例:

sqlite3_stmt *statement;
sqlite3_prepare_v2(db, "SELECT * FROM users WHERE id=?", -1, &statement, NULL);
sqlite3_bind_int(statement, 1, 1);
int columnCount = sqlite3_column_count(statement);
int result = 0;
while (sqlite3_step(statement) == SQLITE_ROW) {
    int dataCount = sqlite3_data_count(statement);
    if (dataCount > 0) {
        printf("Found %d record(s):\n", dataCount);
        for (int i = 0; i < columnCount; i++) {
            const char *name = sqlite3_column_name(statement, i);
            const char *value = (char *)sqlite3_column_text(statement, i);
            printf("%s = %s\n", name, value);
        }
        result = 1; // 标记有数据返回
    } else {
        printf("No records found\n");
    }
}
sqlite3_finalize(statement);
if (result == 0) {
    printf("No data returned\n");
}

在上面的示例中,我们使用 sqlite3_prepare_v2 函数准备 SQL 语句,并绑定一个参数。然后使用 sqlite3_data_count 函数检查查询结果集中是否有数据。如果有数据,则使用 sqlite3_column_name 和 sqlite3_column_text 函数获取每列的名称和值,并打印出来。

注意:使用 sqlite3_data_count 函数只能用于检查查询语句返回的结果集中是否有数据,不能用于获取数据的内容,因为该函数只返回列数信息,而不是具体的列值。

40、sqlite3_db_handle  

sqlite3_db_handle 函数用于获取 SQLite 数据库连接句柄。该函数的返回值是一个 sqlite3 * 类型的指针,可以用于执行一些高级的 SQLite 操作,如 SQLite 多线程控制。

sqlite3 *sqlite3_db_handle(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经通过 `sqlite3_prepare_v2` 编译过的 SQLite 语句。

返回值:

- 返回 SQLite 数据库连接句柄。

以下是一个示例:

sqlite3 *db;
sqlite3_open("test.db", &db);
sqlite3_exec(db, "CREATE TABLE users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)", NULL, NULL, NULL);
sqlite3_stmt *statement;
sqlite3_prepare_v2(db, "INSERT INTO users (name, age) VALUES (?, ?)", -1, &statement, NULL);
sqlite3_bind_text(statement, 1, "张三", -1, NULL);
sqlite3_bind_int(statement, 2, 18);
sqlite3_step(statement);
sqlite3_finalize(statement);
sqlite3 *conn = sqlite3_db_handle(statement);
printf("Database name: %s\n", sqlite3_db_filename(conn, "main"));
sqlite3_close(db);

在上面的示例中,我们首先打开 SQLite 数据库,创建一个名为 users 的表,并向表中插入一条数据。然后使用 sqlite3_db_handle 函数获取与 SQLite 数据库连接相关联的句柄,并使用 sqlite3_db_filename 函数获取数据库文件名,最后关闭数据库连接。

注意:使用 sqlite3_db_handle 函数需要传递一个 SQLite 语句作为参数,以便获取该语句相关联的数据库连接句柄。如果传递 NULL 或未执行任何语句,则该函数返回 NULL。  

41、sqlite3_expanded_sql 

sqlite3_expanded_sql 函数用于获取 SQL 语句在编译后的完整字符串,包括了参数值的替换,可用于调试和日志记录。

char *sqlite3_expanded_sql(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经通过 `sqlite3_prepare_v2` 编译过的 SQLite 语句。

返回值:

- 返回 SQL 语句编译后的完整字符串,包括参数值的替换。

以下是一个示例:

sqlite3_stmt *statement;
sqlite3_prepare_v2(db, "SELECT * FROM users WHERE name=? AND age=?", -1, &statement, NULL);
sqlite3_bind_text(statement, 1, "张三", -1, NULL);
sqlite3_bind_int(statement, 2, 18);
const char *expandedSql = sqlite3_expanded_sql(statement);
printf("SQL: %s\n", expandedSql);
sqlite3_free((void *)expandedSql);

在上面的示例中,我们使用 sqlite3_prepare_v2 函数准备 SQL 语句,并绑定两个参数。然后使用 sqlite3_expanded_sql 函数获取 SQL 语句的完整字符串,并打印出来。最后使用 sqlite3_free 函数释放内存。

注意:使用 sqlite3_expanded_sql 函数需要传递一个已编译的 SQLite 语句作为参数,而不是未编译的 SQL 语句。

42、sqlite3_normalized_sql      

sqlite3_normalized_sql 函数用于获取 SQL 语句在编译后的规范化字符串,该字符串具有以下特点:

- 所有空格都被移除。
- 所有字符串常量被替换为 '?'。
- 所有转义字符被移除。

该函数可用于查询缓存,因为规范化字符串可以更容易地进行比较。

const char *sqlite3_normalized_sql(sqlite3_stmt *pStmt);

参数说明:

- pStmt:已经通过 `sqlite3_prepare_v2` 编译过的 SQLite 语句。

返回值:

- 返回 SQL 语句编译后的规范化字符串。

以下是一个示例:

sqlite3_stmt *statement;
sqlite3_prepare_v2(db, "SELECT * FROM users WHERE name=? AND age=?", -1, &statement, NULL);
sqlite3_bind_text(statement, 1, "张三", -1, NULL);
sqlite3_bind_int(statement, 2, 18);
const char *normalizedSql = sqlite3_normalized_sql(statement);
printf("Normalized SQL: %s\n", normalizedSql);
sqlite3_free((void *)normalizedSql);

在上面的示例中,我们使用 sqlite3_prepare_v2 函数准备 SQL 语句,并绑定两个参数。然后使用 sqlite3_normalized_sql 函数获取 SQL 语句的规范化字符串,并打印出来。最后使用 sqlite3_free 函数释放内存。

注意:使用 sqlite3_normalized_sql 函数需要传递一个已编译的 SQLite 语句作为参数,而不是未编译的 SQL 语句。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux 驱动基础】第一个驱动

# 前置知识 APP 打开文件时&#xff0c;可以得到一个整数&#xff0c;这个整数被称为文件句柄。对于 APP的每一个文件句柄&#xff0c;在内核里面都有一个“ struct file”与之对应。 使用open函数时&#xff0c;用户态调用 API 触发异常进入内核内核识别异常后&#xff0c;取…

【理解机器学习算法】之Clustering算法(Agglomerative Clustering)

聚合聚类(Agglomerative Clustering)是一种层次聚类算法&#xff0c;通过逐步合并或“聚集”它们来构建嵌套聚类。这种方法采用自底向上的方式构建聚类层次&#xff1a;它从将每个数据点作为单个聚类开始&#xff0c;然后迭代合并最接近的聚类对&#xff0c;直到所有数据点合并…

学习添加03(优惠卷)

1.优化卷模块的介绍 整体流程&#xff1a; 优惠卷表设计&#xff1a; 优惠卷范围表设计&#xff1a; 兑换码表设计&#xff1a;

【嵌入式——QT】Charts常见的图表的绘制

【嵌入式——QT】Charts常见的图表的绘制 柱状图QBarSetQBarSeriesQBarCategoryAxis图示 饼图堆叠柱状图百分比柱状图散点图和光滑曲线图代码示例 柱状图 QBarSet 用于创建柱状图的数据集。 主要函数 setLabel()&#xff1a;设置数据集标签 &#xff1b;setLabelBrush()&am…

解决arco-design下拉框回显id的问题

问题描述 下拉框回显选项中没有的选项&#xff0c;就会出现以下情况&#xff0c;只能把uid回显上去 解决方案 使用ui框架自带的属性fallback-option 用法 按以上操作&#xff0c;即可解决选择框回显uid问题

【数据结构】——排序之冒泡排序

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

使用CSS3画出一个叮当猫HTML源码

我们经常使用PS或者Flash制作动画&#xff0c;本文则介绍了如何用CSS3画出个叮当猫&#xff0c;实现过程很有趣&#xff0c;感兴趣的朋友可以参考一下 首先&#xff0c;先把HTML结构搭建好&#xff1a; <div class"wrapper"> <!--叮当猫整体--> <di…

【3GPP】【核心网】【4G】4G手机接入过程,手机附着过程(超详细)

1. 4G手机接入过程&#xff0c;手机附着过程 附着&#xff08;Attach&#xff09;&#xff1a; 终端在PLMN中注册&#xff0c;从而建立自己的档案&#xff0c;即终端上下文 进行附着的三种情况&#xff1a; ①终端开机后的附着&#xff0c;初始附着 ②终端从覆盖盲区返回到…

Day41:WEB攻防-ASP应用HTTP.SYS短文件文件解析Access注入数据库泄漏

目录 ASP-默认安装-MDB数据库泄漏下载 ASP-中间件-CVE&短文件&解析&写权限 HTTP.SYS&#xff08;CVE-2015-1635&#xff09;主要用作蓝屏破坏&#xff0c;跟权限不挂钩 IIS短文件(iis全版本都可能有这个问题) IIS文件解析 IIS写权限 ASP-SQL注入-SQLMAP使用…

基于python+vue的OA公文发文管理系统flask-django-php-nodejs

系统根据现有的管理模块进行开发和扩展&#xff0c;采用面向对象的开发的思想和结构化的开发方法对OA公文发文管理的现状进行系统调查。采用结构化的分析设计&#xff0c;该方法要求结合一定的图表&#xff0c;在模块化的基础上进行系统的开发工作。在设计中采用“自下而上”的…

数据挖掘与分析学习笔记

一、Numpy NumPy&#xff08;Numerical Python&#xff09;是一种开源的Python库&#xff0c;专注于数值计算和处理多维数组。它是Python数据科学和机器学习生态系统的基础工具包之一&#xff0c;因为它高效地实现了向量化计算&#xff0c;并提供了对大型多维数组和矩阵的支持…

鸿蒙预览报错 Only files in a module can be previewed

HarmonyOS第一课下载的源码无法运行&#xff0c;也无法预览&#xff0c;报错如题。 解决&#xff1a; 1、在预览页如“index.ets”文件下预览。 2、如果在通知栏看到如图提示&#xff0c;可看出是ohos/hvigor-ohos-plugin插件版本的问题&#xff0c;可点击蓝色解决方案同步并导…

01-Spark的Local模式与应用开发入门

1 Spark 的 local 模式 Spark 运行模式之一&#xff0c;用于在本地机器上单机模拟分布式计算的环境。在 local 模式下&#xff0c;Spark 会使用单个 JVM 进程来模拟分布式集群行为&#xff0c;所有 Spark 组件&#xff08;如 SparkContext、Executor 等&#xff09;都运行在同…

获取淘宝商品评论的爬虫技术分享(已封装API,可测试)

item_review-获得淘宝商品评论 公共参数 请求地址: taobao/item_review 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[item_search,it…

基于python+vue网络相册设计与实现flask-django-nodejs-php

网络相册设计与实现的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品&#xff0c;体验高科技时代带给人们的方便&#xff0c;同时也能让用户体会到与以往常规产品不同的体验风格。 与安卓&#xff0c;iOS相比较起来&#xff0…

python 函数(解包**、互相调用、作用域、函数的封装、内置函数:eval()、zip()、文件处理open())

函数解包 """ 1、函数的注释&#xff1a;参数和返回值 在注释里可以自动添加显示&#xff0c;只需手动加说明。2、函数的解包【拆包】&#xff1a;函数的参数要传递数据有多个值的时候&#xff0c;中间步骤拿到数据 保存在元组或者列表 或者字典里。 - 传递参数…

机器学习-06-无监督算法-01-划分聚类Kmeans算法

总结 本系列是机器学习课程的系列课程&#xff0c;主要介绍机器学习中无监督算法&#xff0c;包括划分聚类等。 参考 数据分析实战 | K-means算法——蛋白质消费特征分析 欧洲48国英文名称的来龙去脉及其国旗动画 Kmeans在线动态演示 本门课程的目标 完成一个特定行业的…

【C#】使用C#窗体应用开启/停止Apache、MySQL服务

目录 一、前言 二、效果图 三、配置文件 四、代码 五、一键启动/停止所有服务 一、前言 使用C#窗体应用开启Apache、MySQL服务&#xff0c;不仅仅是Apache、MySQL&#xff0c;其他服务也可以使用同样的方法操作&#xff0c;包括开启自己写的脚本服务。 二、效果图 两种状…

短视频矩阵系统--技术实际开发打板3年真实开发分享

短视频矩阵系统--技术实际开发打板3年真实开发分享&#xff0c;短视频矩阵系统/矩阵获客系统是一种基于短视频平台的获客游戏。短视频矩阵系统可以通过多账号发布来替代传统的单账号游戏。可以一键发布所有账号&#xff0c;批量制作多个视频AI智能剪辑。过去很多人只能完成的工…

新版仿蓝奏网盘|城通网盘|百度网盘|闪客网盘|网盘源码系统,个人网盘系统

(购买本专栏可免费下载栏目内所有资源不受限制,持续发布中,需要注意的是,本专栏为批量下载专用,并无法保证某款源码或者插件绝对可用,介意不要购买!购买本专栏住如有什么源码需要,可向博主私信,第二天即可发布!博主有几万资源) 这是一款仿蓝奏网盘、城通网盘、百…