当前位置: 首页 > 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;雏菊、蒲公英、玫瑰、向日葵…...

分布式存储技术全景解析:从架构演进到场景实践

目录 技术演进与市场新格局核心架构设计深度剖析前沿技术创新与性能突破行业应用场景实践挑战与未来发展趋势1. 技术演进与市场新格局 1.1 从集中式到分布式的范式转移 传统集中式存储(如NAS/SAN)在扩展性和容错性方面面临根本性瓶颈,而分布式存储通过水平扩展架构和多节点…...

NVMe协议简介之AXI总线更新

更新AXI4总线知识 AXI4总线协议 AXI4总线协议是由ARM公司提出的一种片内总线协议 &#xff0c;旨在实现SOC中各模块之间的高效可靠的数据传输和管理。AXI4协议具有高性能、高吞吐量和低延迟等优点&#xff0c;在SOC设计中被广泛应用 。随着时间的推移&#xff0c;AXI4的影响不…...

基于Android的医院陪诊预约系统

博主介绍&#xff1a;java高级开发&#xff0c;从事互联网行业六年&#xff0c;熟悉各种主流语言&#xff0c;精通java、python、php、爬虫、web开发&#xff0c;已经做了六年的毕业设计程序开发&#xff0c;开发过上千套毕业设计程序&#xff0c;没有什么华丽的语言&#xff0…...

Ubuntu20.04服务器开启路由转发让局域网内其他电脑通过该服务器连接外网

要让你的 Ubuntu作为路由器&#xff0c;通过 Wi-Fi 上网&#xff0c;并给连接到 UsbNetwork 的设备提供网络&#xff0c;需要做以下配置&#xff1a; 1. 网络拓扑 [互联网] ← (Wi-Fi, wlo1) → [Ubuntu] ← (USB网络/USB以太网, UsbNetwork) → [设备]Ubuntu&#xff1a; Wi-…...

【算法】分支限界

一、基本思想 &#xff08;分支限界&#xff0c; 分枝限界&#xff0c; 分支界限 文献不同说法但都是一样的&#xff09; 分支限界法类似于回溯法&#xff0c;也是一种在问题的解空间树上搜索问题解的算法。 但一般情况下&#xff0c;分支限界法与回溯法的求解目标不同。回溯…...

一天搞懂深度学习--李宏毅教程笔记

目录 1. Introduction of Deep Learning1.1. Neural Network - A Set of Function1.2. Learning Target - Define the goodness of a function1.3. Learn! - Pick the best functionLocal minimaBackpropagation 2. Tips for Training Deep Neural Network3. Variant of Neural…...

C/C++ OpenCV 矩阵运算

C/C OpenCV 矩阵运算详解 &#x1f4a1; OpenCV 是一个强大的开源计算机视觉和机器学习库&#xff0c;它提供了丰富的矩阵运算功能&#xff0c;这对于图像处理和计算机视觉算法至关重要。本文将详细介绍如何使用 C/C 和 OpenCV 进行常见的矩阵运算。 矩阵的创建与初始化 在进…...

基于大数据的个性化购房推荐系统设计与实现(源码+定制+开发)面向房产电商的智能购房推荐与数据可视化系统 基于Spark与Hive的房源数据挖掘与推荐系统设计

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…...

android 上位机调试软件-安卓串口 com ttl 调试——仙盟创梦IDE

在 Android 开发中&#xff0c;基于com.ttl库的串口调试 Web 编写意义非凡。它打破了硬件与软件之间的壁垒&#xff0c;让 Android 设备能够与外部串口设备通信。对于智能家居、工业控制等领域&#xff0c;这一功能使得手机或平板能成为控制终端&#xff0c;实现远程监控与操作…...

【GlobalMapper精品教程】095:如何获取无人机照片的拍摄方位角

文章目录 一、加载无人机照片二、计算方位角三、Globalmapper符号化显示方向四、arcgis符号化显示方向一、加载无人机照片 打开软件,加载无人机照片,在GLobalmapperV26中文版中,默认显示如下的航线信息。 关于航线的起止问题,可以直接从照片名称来确定。 二、计算方位角 …...