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

​​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类(十一)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;​​SQLiteC/C接口详细介绍之sqlite3类&#xff08;十&#xff09; 下一篇&#xff1a;​​SQLiteC/C接口详细介绍之sqlite3类&#xff08;十二&#xff09;&#xff08;未发表&#xff09; 33.sq…...

百度智能云+SpringBoot=AI对话【人工智能】

百度智能云SpringBootAI对话【人工智能】 前言版权推荐百度智能云SpringBootAI对话【人工智能】效果演示登录AI对话 项目结构后端开发pom和propertiessql_table和entitydao和mapperservice和implconfig和utilLoginController和ChatController 前端开发css和jslogin.html和chat.…...

第二十七节 Java 多态

本章主要为大家介绍java多态的概念&#xff0c;以及便于理解的多态简单例子。 Java 多态 多态是同一个行为具有多个不同表现形式或形态的能力。 多态性是对象多种表现形式的体现。 比如我们说"宠物"这个对象&#xff0c;它就有很多不同的表达或实现&#xff0c;比…...

基于Springboot的员工健康管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的员工健康管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构…...

[论文精读]Dynamic Coarse-to-Fine Learning for Oriented Tiny Object Detection

论文网址&#xff1a;[2304.08876] 用于定向微小目标检测的动态粗到细学习 (arxiv.org) 论文代码&#xff1a;https://github.com/ChaselTsui/mmrotate-dcfl 英文是纯手打的&#xff01;论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&…...

Selenium WebDriver 中用于查找网页元素的两个方法

这里提供了 Selenium WebDriver 中用于查找元素的两个方法&#xff1a;find_element() 和 find_elements()。 find_element(byid, value: Optional[str] None) → selenium.webdriver.remote.webelement.WebElement 这个方法用于查找满足指定定位策略&#xff08;By strategy&…...

python 常用装饰器

文章目录 property的介绍与使用作用使用场景装饰方法防止属性被修改 实现setter和getter的行为 staticmethod 与 classmethod作用代码示例 两者区别使用区别代码演示 abstractmethod参考资料 property的介绍与使用 python的property是python的一种装饰器&#xff0c;是用来修饰…...

深入解析MySQL日志系统:Binlog、Undo Log和Redo Log

在数据库系统中&#xff0c;日志文件扮演着至关重要的角色&#xff0c;它们不仅保证了数据的完整性和一致性&#xff0c;还支持了数据的恢复、复制和审计等功能。MySQL数据库中最核心的日志系统包括二进制日志&#xff08;Binlog&#xff09;、回滚日志&#xff08;Undo Log&am…...

强森算法求两点最短路径的基本流程及代码实现

对于强森算法,给定的一个图中,算法首先会构造一个新的节点s,然后从新构造的这个节点引出多条边分别连通图中的每一个节点,这些边的长度一开始是被设置为0的,然后使用贝尔曼-福德算法进行计算,算出从s到图中每一个节点的最短路径。 而在运行贝尔曼-福德算法的过程中如果发…...

数据结构入门篇 之 【双链表】的实现讲解(附完整实现代码及顺序表与线性表的优缺点对比)

一日读书一日功&#xff0c;一日不读十日空 书中自有颜如玉&#xff0c;书中自有黄金屋 一、双链表 1、双链表的结构 2、双链表的实现 1&#xff09;、双向链表中节点的结构定义 2&#xff09;、初始化函数 LTInit 3&#xff09;、尾插函数 LTPushBack 4&#xff09;、头…...

什么是零日攻击?

一、零日攻击的概念 零日攻击是指利用零日漏洞对系统或软件应用发动的网络攻击。 零日漏洞也称零时差漏洞&#xff0c;通常是指还没有补丁的安全漏洞。由于零日漏洞的严重级别通常较高&#xff0c;所以零日攻击往往也具有很大的破坏性。 目前&#xff0c;任何安全产品或解决方案…...

阿里云2025届春招实习生招聘

投递时间&#xff1a;2024年2月1日-2026年3月1日 岗位职责 负责大型客户“上云”&#xff0c;"用云"技术平台开发。 开发云迁移运维技术工具&#xff0c;帮助阿里云服务团队&&企业客户和服务商自主、高效的完成云迁移。 开发云运维技术工具&#xff0c;帮助…...

简单了解多线程

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

GEE对上传并读取CSV文件

首先在Assets中上传csv csv格式如下所示&#xff1a; 上传好了之后&#xff0c;来看看这个表能否显示 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分配器&#xff1f; 用户态程序可以使用malloc及其在C标准库中的相关函数申请内存&#xff1b;内核也需要经常分配内存&#xff0c;但无法使用标准库函数&#xff1b;linux内核中&#xff0c;伙伴分配器是一种页分配器&#xff0c;是以页为单位的&#xff0c;但这个…...

MySQL面试题之基础夯实

一、mysql当中的基本数据类型有哪些 MySQL中的基本数据类型包括但不限于以下几大类&#xff1a; 数值类型&#xff1a; 整数类型&#xff1a;TINYINT、SMALLINT、MEDIUMINT、INT&#xff08;INTEGER&#xff09;、BIGINT浮点数类型&#xff1a;FLOAT、DOUBLE、DECIMAL&#xf…...

feign请求添加拦截器

FeignClient 的 configuration 属性&#xff1a; Feign 注解 FeignClient 的 configuration 属性&#xff0c;可以对 feign 的请求进行配置。 包括配置Feign的Encoder、Decoder、 Interceptor 等。 feign 请求添加拦截器&#xff0c;也可以通过这个 configuration 属性 来指…...

蓝桥杯之简单数论冲刺

文章目录 取模快速幂 取模 这道题目有两个注意点&#xff1a; 1.当你的取模之后刚好等于0的话&#xff0c;后面就不用进行后面的计算 2.if sum detail[i] > q: 这个语句的等号也很重要 import os import sys# 请在此输入您的代码a,b,n map(int,input().split())week a*5 …...

Http的缓存有哪些

HTTP 缓存可以通过多种 HTTP 头部字段来控制&#xff0c;主要包括以下几种&#xff1a; 1.Expires&#xff1a;这个字段定义了响应的过期时间。如果当前时间小于 Expires 的时间&#xff0c;那么就可以直接使用缓存。 2.Cache-Control&#xff1a;这个字段是一个指令&#xff…...

挑战杯推荐项目

“人工智能”创意赛 - 智能艺术创作助手&#xff1a;借助大模型技术&#xff0c;开发能根据用户输入的主题、风格等要求&#xff0c;生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用&#xff0c;帮助艺术家和创意爱好者激发创意、提高创作效率。 ​ - 个性化梦境…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

C# 求圆面积的程序(Program to find area of a circle)

给定半径r&#xff0c;求圆的面积。圆的面积应精确到小数点后5位。 例子&#xff1a; 输入&#xff1a;r 5 输出&#xff1a;78.53982 解释&#xff1a;由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982&#xff0c;因为我们只保留小数点后 5 位数字。 输…...

Spring是如何解决Bean的循环依赖:三级缓存机制

1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间‌互相持有对方引用‌,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...

探索Selenium:自动化测试的神奇钥匙

目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下&#xff0c;推客小程序系统凭借其裂变传播、精准营销等特性&#xff0c;成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径&#xff0c;助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析

Java求职者面试指南&#xff1a;Spring、Spring Boot、Spring MVC与MyBatis技术解析 一、第一轮基础概念问题 1. Spring框架的核心容器是什么&#xff1f;它的作用是什么&#xff1f; Spring框架的核心容器是IoC&#xff08;控制反转&#xff09;容器。它的主要作用是管理对…...

网页端 js 读取发票里的二维码信息(图片和PDF格式)

起因 为了实现在报销流程中&#xff0c;发票不能重用的限制&#xff0c;发票上传后&#xff0c;希望能读出发票号&#xff0c;并记录发票号已用&#xff0c;下次不再可用于报销。 基于上面的需求&#xff0c;研究了OCR 的方式和读PDF的方式&#xff0c;实际是可行的&#xff…...

HTML中各种标签的作用

一、HTML文件主要标签结构及说明 1. <&#xff01;DOCTYPE html> 作用&#xff1a;声明文档类型&#xff0c;告知浏览器这是 HTML5 文档。 必须&#xff1a;是。 2. <html lang“zh”>. </html> 作用&#xff1a;包裹整个网页内容&#xff0c;lang"z…...