当前位置: 首页 > news >正文

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 语句。

相关文章:

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

返回&#xff1a;SQLite—系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;九&#xff09; 下一篇&#xff1a; SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;十一&#xff09; 38、sqlite3_column_value sqlite3_column_valu…...

Android 生成Excel文件保存到本地

本文用来记录在安卓中生成Excel文件并保存到本地操作&#xff0c;在网上找了好久&#xff0c;终于找到一个可以用的&#xff0c;虽然代码已经很老的&#xff0c;但亲测可用&#xff01; 项目地址&#xff1a;https://github.com/wanganan/AndroidExcel 可以下载下来修改直接用…...

Hive-技术补充-ANTLR语法编写

一、导读 我们学习一门语言&#xff0c;或外语或编程语言&#xff0c;是不是都是要先学语法&#xff0c;想想这些语言有哪些相同点 1、中文、英语、日语......是不是都有 主谓宾 的规则 2、c、java、python、js......是不是都有 数据类型 、循环 等语法或数据结构 虽然人们在…...

6.使用个人用户登录域控的成员服务器,如何防止个人用户账号的用户策略生效?

&#xff08;1&#xff09;需求&#xff1a; &#xff08;2&#xff09;实战配置步骤 第一步:创建新的策略-并编辑策略 第二步&#xff1a;将策略应用到服务器处在OU 第三步&#xff1a;测试 &#xff08;1&#xff09;需求&#xff1a; 比如域控&#xff0c;或者加入域的…...

模拟算法

例题一 算法思路&#xff1a; 纯模拟。从前往后遍历整个字符串&#xff0c;找到问号之后&#xff0c;就⽤ a ~ z 的每⼀个字符去尝试替换即 可。 例题二 解法&#xff08;模拟 分情况讨论&#xff09;&#xff1a; 算法思路&#xff1a; 模拟 分情况讨论。 计算相邻两个…...

【数据结构刷题专题】—— 二叉树

二叉树 二叉树刷题框架 二叉树的定义&#xff1a; struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(NULL), right(NULL); };1 二叉树的遍历方式 【1】前序遍历 class Solution { public:void traversal(TreeNode* node, vector&…...

基于AWS云服务构建智能家居系统的最佳实践

在当今智能家居时代,构建一个安全、高性能、可扩展和灵活的智能家居系统已经成为许多公司的目标。亚马逊网络服务(AWS)提供了一系列云服务,可以帮助企业轻松构建和管理智能家居系统。本文将探讨如何利用AWS云服务构建一个智能家居系统,并分享相关的最佳实践。 系统架构概述 该…...

Java零基础-集合:Set接口

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…...

数据结构与算法-排序算法

1.顺序查找 def linear_search(iters, val):for i, v in enumerate(iters):if v val:return ireturn 2.二分查找 # 升序的二分查找 def binary_search(iters, val):left 0right len(iters)-1while left < right:mid (left right) // 2if iters[mid] val:return mid…...

SpringBoot 文件上传(三)

之前讲解了如何接收文件以及如何保存到服务端的本地磁盘中&#xff1a; SpringBoot 文件上传&#xff08;一)-CSDN博客 SpringBoot 文件上传&#xff08;二&#xff09;-CSDN博客 这节讲解如何利用阿里云提供的OSS&#xff08;Object Storage Service)对象存储服务保存文件。…...

web渗透测试漏洞流程:红队目标信息收集之资产搜索引擎收集

web渗透测试漏洞流程 渗透测试信息收集---域名信息收集1.域名信息的科普1.1 域名的概念1.2 后缀分类1.3 多重域名的关系1.4 域名收集的作用1.5 DNS解析原理1.6 域名解析记录2. 域名信息的收集的方法2.1 基础方法-搜索引擎语法2.1.1 Google搜索引擎2.1.1.1 Google语法的基本使用…...

UI自动化_id 元素定位

## 导包selenium from selenium import webdriver import time1、创建浏览器驱动对象 driver webdriver.Chrome() 2、打开测试网站 driver.get("你公司的平台地址") 3、使浏览器窗口最大化 driver.maximize_window() 4、在用户名输入框中输入admin driver.find_ele…...

华为OD技术面算法题整理

LeetCode原题 简单 题目编号频次409. 最长回文串 - 力扣(LeetCode)3...

vmware虚拟机下ubuntu扩大磁盘容量

1、扩容&#xff1a; 可以直接在ubuntu setting界面里直接扩容&#xff0c;也可通过vmware命令&#xff0c;如下&#xff1a; vmware提供一个命令行工具&#xff0c;vmware-vdiskmanager.exe&#xff0c;位于vmware的安装目录下&#xff0c;比如 C:/Program Files/VMware/VMwar…...

秋招打卡算法题第一天

一年多没有刷过算法题了&#xff0c;已经不打算找计算机类工作了&#xff0c;但是思来想去&#xff0c;还是继续找吧。 1. 字符串最后一个单词的长度 public static void main(String[] args) {Scanner in new Scanner(System.in);while(in.hasNextInt()){String itemin.nextL…...

BC98 序列中删除指定数字

题目 描述 有一个整数序列&#xff08;可能有重复的整数&#xff09;&#xff0c;现删除指定的某一个整数&#xff0c;输出删除指定数字之后的序列&#xff0c;序列中未被删除数字的前后位置没有发生改变。 数据范围&#xff1a;序列长度和序列中的值都满足 1≤&#xfffd;≤…...

基于Java的学生体质健康管理系统的设计与实现(论文+源码)_kaic

摘 要 随着时代的进步&#xff0c;信息化也在逐渐深入融进我们生活的方方面面。其中也给健康管理带来了新的发展方向。通过对学生体质健康管理的研究与分析发现当下的管理系统还不够全面&#xff0c;系统的性能达不到使用者的要求。因此&#xff0c;本文结合Java的优势和流行性…...

【Linux系统】冯诺依曼与操作系统

什么是冯诺依曼体系结构&#xff1f; 如图即为冯诺依曼大致的体系结构图&#xff0c; 我们知道这些都是由我们的计算机硬件组成 输入设备&#xff1a;键盘&#xff0c; 鼠标&#xff0c; 摄像头&#xff0c; 话筒&#xff0c; 磁盘&#xff0c; 网卡... 输出设备&#xff1a…...

前端理论总结(html5)——form表单的新增特性/h5的新特性

form表单的新增特性 range&#xff1a;范围 color&#xff1a;取色器 url&#xff1a;对url进行验证 tel&#xff1a;对手机号格式验证 email&#xff1a;对邮箱格式验证 novalidate &#xff1a;提交表单时不验证 form 或 input 域 numbe…...

基于TensorFlow的花卉识别(算能杯)%%%

Anaconda Prompt 激活 TensorFlow CPU版本 conda activate tensorflow_cpu //配合PyCharm环境 直接使用TensorFlow1.数据分析 此次设计的主题为花卉识别&#xff0c;数据为TensorFlow的官方数据集flower_photos&#xff0c;包括5种花卉&#xff08;雏菊、蒲公英、玫瑰、向日葵…...

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...

RocketMQ延迟消息机制

两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数&#xff0c;对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后&#xf…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件

在选煤厂、化工厂、钢铁厂等过程生产型企业&#xff0c;其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进&#xff0c;需提前预防假检、错检、漏检&#xff0c;推动智慧生产运维系统数据的流动和现场赋能应用。同时&#xff0c;…...

定时器任务——若依源码分析

分析util包下面的工具类schedule utils&#xff1a; ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类&#xff0c;封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz&#xff0c;先构建任务的 JobD…...

反射获取方法和属性

Java反射获取方法 在Java中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的机制&#xff0c;允许程序在运行时访问和操作类的内部属性和方法。通过反射&#xff0c;可以动态地创建对象、调用方法、改变属性值&#xff0c;这在很多Java框架中如Spring和Hiberna…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

2023赣州旅游投资集团

单选题 1.“不登高山&#xff0c;不知天之高也&#xff1b;不临深溪&#xff0c;不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

边缘计算网关提升水产养殖尾水处理的远程运维效率

一、项目背景 随着水产养殖行业的快速发展&#xff0c;养殖尾水的处理成为了一个亟待解决的环保问题。传统的尾水处理方式不仅效率低下&#xff0c;而且难以实现精准监控和管理。为了提升尾水处理的效果和效率&#xff0c;同时降低人力成本&#xff0c;某大型水产养殖企业决定…...

ZYNQ学习记录FPGA(二)Verilog语言

一、Verilog简介 1.1 HDL&#xff08;Hardware Description language&#xff09; 在解释HDL之前&#xff0c;先来了解一下数字系统设计的流程&#xff1a;逻辑设计 -> 电路实现 -> 系统验证。 逻辑设计又称前端&#xff0c;在这个过程中就需要用到HDL&#xff0c;正文…...

Qt Quick Controls模块功能及架构

Qt Quick Controls是Qt Quick的一个附加模块&#xff0c;提供了一套用于构建完整用户界面的UI控件。在Qt 6.0中&#xff0c;这个模块经历了重大重构和改进。 一、主要功能和特点 1. 架构重构 完全重写了底层架构&#xff0c;与Qt Quick更紧密集成 移除了对Qt Widgets的依赖&…...