SQLiteC/C++接口详细介绍之sqlite3类(十一)
返回目录:SQLite—免费开源数据库系列文章目录
上一篇:SQLiteC/C++接口详细介绍之sqlite3类(十)
下一篇:SQLiteC/C++接口详细介绍之sqlite3类(十二)(未发表)
33.sqlite3_free_table
sqlite3_free_table是SQLite3 C API提供的一个函数,用于释放由sqlite3_get_table函数获取的结果集中的内存。当SQLite3返回查询结果时,可能会根据结果集的行数和列数动态分配内存,用于存储查询结果。这时需要使用sqlite3_free_table函数来释放这些动态分配的内存。
该函数的具体形式为:
void sqlite3_free_table(char **result);
其中,result是一个指向结果集的指针,可以使用sqlite3_get_table函数获取。
需要注意的是,sqlite3_free_table函数只能释放sqlite3_get_table函数所分配的内存,不能释放其他任何内存块,否则可能会导致程序崩溃或者数据错误。下面是一个简单的示例,展示如何使用sqlite3_get_table函数获取SQLite3查询结果,并使用sqlite3_free_table函数释放相关的内存。
#include <sqlite3.h>
#include <stdio.h
int main(int argc, char* argv[]) {sqlite3* db;int rc;// 打开数据库rc = sqlite3_open("test.db", &db);if (rc != SQLITE_OK) {printf("Can't open database: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}// 执行查询语句char* sql = "SELECT id, name, age FROM person";char** result;int nrow, ncol;rc = sqlite3_get_table(db, sql, &result, &nrow, &ncol, NULL);if (rc != SQLITE_OK) {printf("SQL error: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}// 输出结果for (int i = 0; i <= nrow; i++) {for (int j = 0; j < ncol; j++) {printf("%s\t", result[i * ncol + j]);}printf("\n");}// 释放内存sqlite3_free_table(result);// 关闭数据库sqlite3_close(db);return 0;
}
在上面的示例代码中,我们使用sqlite3_get_table函数执行一条SELECT语句,并将查询结果存储在result变量中。然后,使用两重循环遍历结果集,输出查询结果。
在使用完查询结果后,需要使用sqlite3_free_table函数释放result中的动态分配的内存,避免出现内存泄漏问题。
34.sqlite3_get_autocommit
用于查询当前数据库连接是否处于自动提交模式。
在SQLite3中,事务是由程序员来手动控制的,开发者可以在合适的时候调用BEGIN、COMMIT、ROLLBACK等命令来开始、提交或者回滚事务。而自动提交模式下,每个SQL语句都将会自动成为一个事务,如果执行成功,则自动提交;如果执行失败,则自动回滚。默认情况下,SQLite3的连接是处于自动提交模式下的,可以通过sqlite3_exec函数或者sqlite3_prepare函数来执行SQL语句。通过sqlite3_get_autocommit函数可以了解当前连接是否处于自动提交模式。
该函数的具体形式为:
int sqlite3_get_autocommit(sqlite3 *db);
其中,db是一个指向SQLite3数据库实例的指针。
返回值为1表示自动提交模式,返回值为0表示手动控制模式。
下面是一个简单的示例,展示如何使用sqlite3_get_autocommit函数查询当前数据库连接是否处于自动提交模式。
#include <sqlite3.h>
#include <stdio.h>
int main(int argc, char* argv[]) {sqlite3* db;int rc;// 打开数据库rc = sqlite3_open("test.db", &db);if (rc != SQLITE_OK) {printf("Can't open database: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}// 执行查询操作int autocommit = sqlite3_get_autocommit(db);if (autocommit) {printf("Connection is in auto-commit mode.\n");} else {printf("Connection is not in auto-commit mode.\n");}// 关闭数据库sqlite3_close(db);return 0;
}
在上面的示例代码中,我们使用sqlite3_get_autocommit函数查询当前数据库连接是否处于自动提交模式。通过查询结果,输出到控制台上。
如果sqlite3_get_autocommit函数返回值为1,表示当前连接处于自动提交模式;如果返回值为0,表示当前连接处于手动控制模式。
35.sqlite3_get_clientdata
sqlite3_get_clientdata是SQLite3 C API提供的一个函数,它用于获取在一个特定连接上设置的客户端数据指针。客户端数据指针是开发人员可以将任何有用的信息与连接关联的一个指针,比如一个回调函数或其他结构体的指针。SQLite3库本身不会使用这个指针,而它将被传递给回调函数或其他应用程序代码,帮助管理连接特定的状态信息。
以下是sqlite3_get_clientdata函数的声明:
void* sqlite3_get_clientdata(sqlite3_context*);
其中,sqlite3_context*是由SQLite3回调函数提供的一个指向函数上下文的指针。
下面是一个简单的例子,展示如何在一个回调函数中将数据指针绑定到一个连接上,并如何在另一个回调函数中检索并使用该数据指针:```c
void my_func_callback(sqlite3_context* ctx, int argc, sqlite3_value** argv)
{// 检索指针并使用它my_data_t* data = (my_data_t*) sqlite3_get_clientdata(ctx);data->some_field = ...;// ...
}
void my_aggregate_step_callback(sqlite3_context* ctx, int argc, sqlite3_value** argv)
{// 检索指针并使用它my_data_t* data = (my_data_t*) sqlite3_get_clientdata(ctx);data->some_other_field += ...;// ...
}
// 初始化连接和绑定回调函数
my_data_t my_data = { 0 };
rc = sqlite3_create_function_v2(db, "my_function", 1, SQLITE_UTF8 | SQLITE_DETERMINISTIC, &my_data, my_func_callback, NULL, NULL, NULL);
rc = sqlite3_create_function_v2(db, "my_aggregate", 1, SQLITE_UTF8 | SQLITE_DETERMINISTIC, &my_data, NULL, my_aggregate_step_callback, NULL, NULL);
在上面的示例代码中,我们首先定义了与连接相关的数据结构——my_data_t,并将它的指针作为第五个参数传递到两个不同的回调函数中,这表明我们需要在连接上绑定一个数据指针。
然后调用sqlite3_create_function_v2函数来在数据库连接上绑定两个回调函数,第五个参数指定我们希望在连接上绑定的客户端数据指针。
然后在回调函数中调用sqlite3_get_clientdata函数来检索该指针,并使用它管理连接特定的状态。
36.sqlite3_limit
sqlite3_limit是SQLite3 C API提供的一个函数,它用于提前动态设置不同类型的限制。
SQLite3是一个嵌入式关系型数据库管理系统,非常适合于在嵌入式系统和移动设备中使用。为了避免在这些受限资源的系统上过度消耗内存和其他资源,SQLite3提供了一些限制类型,以减少对资源的占用。
SQLite3中的限制(limit)包括数据库上限、附加数据库上限、单一通道SQL语句占用内存限制、执行器线程的最大数量和单条SQL请求执行的语句数等等。sqlite3_limit函数允许开发人员动态地设置各种SQLite3限制类型的值。
以下是sqlite3_limit函数的声明:
int sqlite3_limit(sqlite3*, int id, int newVal);
其中,sqlite3是指向SQLite3数据库实例的指针,id是预先定义的的某个特定类型的限制选项,newVal是与该选项相关联的新值。
以下是一些预先定义的限制标识符和它们的意义:
|LIMIT ID|描述|
|---|---|
|SQLITE_LIMIT_LENGTH|SQL语句的最大长度|
|SQLITE_LIMIT_SQL_LENGTH|列名称、表名称、声明集合长度的SQL语句的最大长度|
|SQLITE_LIMIT_COLUMN|表中列的最大数目|
|SQLITE_LIMIT_EXPR_DEPTH|表达式树中的最大深度(递归层数)|
|SQLITE_LIMIT_COMPOUND_SELECT|select语句中联合查询的最大数量|
|SQLITE_LIMIT_VDBE_OP|虚拟机程序在sqlite3_prepare函数中指定的限制的连续操作数最大值|
下面是一个简单的示例,展示如何使用sqlite3_limit函数设置sqlite3的最大语句长度限制为65536:
#include <sqlite3.h>
#include <stdio.h>
int main(int argc, char* argv[]) {sqlite3* db;int rc;// 打开数据库rc = sqlite3_open("test.db", &db);if (rc != SQLITE_OK) {printf("Can't open database: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}// 设置最大语句长度限制rc = sqlite3_limit(db, SQLITE_LIMIT_LENGTH, 65536);if (rc != SQLITE_OK) {printf("Can't set limit: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}// 关闭数据库sqlite3_close(db);return 0;
}
在上面的示例代码中,我们使用sqlite3_limit函数设置SQLite3的最大可执行SQL语句长度为65536。如果设置操作成功,sqlite3_limit函数将返回SQLITE_OK;如果设置操作失败,将返回一个错误代码。
相关文章:

SQLiteC/C++接口详细介绍之sqlite3类(十一)
返回目录:SQLite—免费开源数据库系列文章目录 上一篇:SQLiteC/C接口详细介绍之sqlite3类(十) 下一篇:SQLiteC/C接口详细介绍之sqlite3类(十二)(未发表) 33.sq…...

百度智能云+SpringBoot=AI对话【人工智能】
百度智能云SpringBootAI对话【人工智能】 前言版权推荐百度智能云SpringBootAI对话【人工智能】效果演示登录AI对话 项目结构后端开发pom和propertiessql_table和entitydao和mapperservice和implconfig和utilLoginController和ChatController 前端开发css和jslogin.html和chat.…...
第二十七节 Java 多态
本章主要为大家介绍java多态的概念,以及便于理解的多态简单例子。 Java 多态 多态是同一个行为具有多个不同表现形式或形态的能力。 多态性是对象多种表现形式的体现。 比如我们说"宠物"这个对象,它就有很多不同的表达或实现,比…...

基于Springboot的员工健康管理系统(有报告)。Javaee项目,springboot项目。
演示视频: 基于Springboot的员工健康管理系统(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构…...

[论文精读]Dynamic Coarse-to-Fine Learning for Oriented Tiny Object Detection
论文网址:[2304.08876] 用于定向微小目标检测的动态粗到细学习 (arxiv.org) 论文代码:https://github.com/ChaselTsui/mmrotate-dcfl 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&…...
Selenium WebDriver 中用于查找网页元素的两个方法
这里提供了 Selenium WebDriver 中用于查找元素的两个方法:find_element() 和 find_elements()。 find_element(byid, value: Optional[str] None) → selenium.webdriver.remote.webelement.WebElement 这个方法用于查找满足指定定位策略(By strategy&…...
python 常用装饰器
文章目录 property的介绍与使用作用使用场景装饰方法防止属性被修改 实现setter和getter的行为 staticmethod 与 classmethod作用代码示例 两者区别使用区别代码演示 abstractmethod参考资料 property的介绍与使用 python的property是python的一种装饰器,是用来修饰…...
深入解析MySQL日志系统:Binlog、Undo Log和Redo Log
在数据库系统中,日志文件扮演着至关重要的角色,它们不仅保证了数据的完整性和一致性,还支持了数据的恢复、复制和审计等功能。MySQL数据库中最核心的日志系统包括二进制日志(Binlog)、回滚日志(Undo Log&am…...
强森算法求两点最短路径的基本流程及代码实现
对于强森算法,给定的一个图中,算法首先会构造一个新的节点s,然后从新构造的这个节点引出多条边分别连通图中的每一个节点,这些边的长度一开始是被设置为0的,然后使用贝尔曼-福德算法进行计算,算出从s到图中每一个节点的最短路径。 而在运行贝尔曼-福德算法的过程中如果发…...

数据结构入门篇 之 【双链表】的实现讲解(附完整实现代码及顺序表与线性表的优缺点对比)
一日读书一日功,一日不读十日空 书中自有颜如玉,书中自有黄金屋 一、双链表 1、双链表的结构 2、双链表的实现 1)、双向链表中节点的结构定义 2)、初始化函数 LTInit 3)、尾插函数 LTPushBack 4)、头…...

什么是零日攻击?
一、零日攻击的概念 零日攻击是指利用零日漏洞对系统或软件应用发动的网络攻击。 零日漏洞也称零时差漏洞,通常是指还没有补丁的安全漏洞。由于零日漏洞的严重级别通常较高,所以零日攻击往往也具有很大的破坏性。 目前,任何安全产品或解决方案…...
阿里云2025届春招实习生招聘
投递时间:2024年2月1日-2026年3月1日 岗位职责 负责大型客户“上云”,"用云"技术平台开发。 开发云迁移运维技术工具,帮助阿里云服务团队&&企业客户和服务商自主、高效的完成云迁移。 开发云运维技术工具,帮助…...

简单了解多线程
并发和并行 并发: 在同一时刻,多个指令在单一CPU上交替指向 并行:在同一时刻,多个指令在多个CPU上同时执行 2核4线程,4核8线程,8核16线程,16核32线程 基础实现线程的方式 Thread :继承类 &…...

GEE对上传并读取CSV文件
首先在Assets中上传csv csv格式如下所示: 上传好了之后,来看看这个表能否显示 var table ee.FeatureCollection("projects/a-flyllf0313/assets/dachang_2022"); var sortedTable table.sort(id); // 替换 propertyName 为你想要排序的属性…...

vulnhub-----SickOS靶机
文章目录 1.信息收集2.curl命令反弹shell提权利用POC 1.信息收集 ┌──(root㉿kali)-[~/kali/vulnhub/sockos] └─# arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:29:10:3c:9b, IPv4: 10.10.10.10 Starting arp-scan 1.9.8 with 256…...

slab分配器
什么是slab分配器? 用户态程序可以使用malloc及其在C标准库中的相关函数申请内存;内核也需要经常分配内存,但无法使用标准库函数;linux内核中,伙伴分配器是一种页分配器,是以页为单位的,但这个…...
MySQL面试题之基础夯实
一、mysql当中的基本数据类型有哪些 MySQL中的基本数据类型包括但不限于以下几大类: 数值类型: 整数类型:TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)、BIGINT浮点数类型:FLOAT、DOUBLE、DECIMAL…...
feign请求添加拦截器
FeignClient 的 configuration 属性: Feign 注解 FeignClient 的 configuration 属性,可以对 feign 的请求进行配置。 包括配置Feign的Encoder、Decoder、 Interceptor 等。 feign 请求添加拦截器,也可以通过这个 configuration 属性 来指…...

蓝桥杯之简单数论冲刺
文章目录 取模快速幂 取模 这道题目有两个注意点: 1.当你的取模之后刚好等于0的话,后面就不用进行后面的计算 2.if sum detail[i] > q: 这个语句的等号也很重要 import os import sys# 请在此输入您的代码a,b,n map(int,input().split())week a*5 …...
Http的缓存有哪些
HTTP 缓存可以通过多种 HTTP 头部字段来控制,主要包括以下几种: 1.Expires:这个字段定义了响应的过期时间。如果当前时间小于 Expires 的时间,那么就可以直接使用缓存。 2.Cache-Control:这个字段是一个指令ÿ…...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...

Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

最新SpringBoot+SpringCloud+Nacos微服务框架分享
文章目录 前言一、服务规划二、架构核心1.cloud的pom2.gateway的异常handler3.gateway的filter4、admin的pom5、admin的登录核心 三、code-helper分享总结 前言 最近有个活蛮赶的,根据Excel列的需求预估的工时直接打骨折,不要问我为什么,主要…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

12.找到字符串中所有字母异位词
🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战
“🤖手搓TuyaAI语音指令 😍秒变表情包大师,让萌系Otto机器人🔥玩出智能新花样!开整!” 🤖 Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制(TuyaAI…...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...

SpringTask-03.入门案例
一.入门案例 启动类: package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...

RNN避坑指南:从数学推导到LSTM/GRU工业级部署实战流程
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在聚客AI学院。 本文全面剖析RNN核心原理,深入讲解梯度消失/爆炸问题,并通过LSTM/GRU结构实现解决方案,提供时间序列预测和文本生成…...

招商蛇口 | 执笔CID,启幕低密生活新境
作为中国城市生长的力量,招商蛇口以“美好生活承载者”为使命,深耕全球111座城市,以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子,招商蛇口始终与城市发展同频共振,以建筑诠释对土地与生活的…...