SQLiteC/C++接口详细介绍之sqlite3类(十六)

 返回目录:SQLite—免费开源数据库系列文章目录 

上一篇:SQLiteC/C++接口详细介绍之sqlite3类(十五)

下一篇: SQLiteC/C++接口详细介绍之sqlite3类(十七)(未发表)

 50.sqlite3_system_errno

函数功能:获取最近一次系统(操作系统)调用发生错误时的错误号(errno)。该函数在SQLite发生系统调用错误时非常有用,可以用于诊断操作系统应该依据errno提供的详细信息进一步解释该错误的根本原因。

函数原型如下:

int sqlite3_system_errno(sqlite3*);

- 参数为指向sqlite3结构体的指针。
- 返回最近一次系统调用发生错误时的错误号(errno)。

下面是一个简单的示例,在代码中我们利用文件不存在这个错误,进行案例的演示:

#include <sqlite3.h>
#include <stdio.h>
#include <errno.h>
int main() {
    sqlite3 *db;
    sqlite3_open(":memory:", &db);
    sqlite3_exec(db, "CREATE TABLE test (id INTEGER PRIMARY KEY, value TEXT)", NULL, NULL, NULL);
    int ret = sqlite3_exec(db, "SELECT * FROM non_existing_table", NULL, NULL, NULL);
    if (ret != SQLITE_OK) {
        printf("SQLite error: %s\n", sqlite3_errmsg(db));
        printf("System error: %d\n", sqlite3_system_errno(db));
        printf("System error message: %s\n", strerror(sqlite3_system_errno(db)));
    }
    sqlite3_close(db);
    return 0;
}

该示例中我们在执行一个不存在的表的查询语句时,会导致SQLITE_ERROR的出现。可以利用sqlite3_system_errno()函数获取系统错误号,并使用strerror()函数将该错误号转换为可读的错误消息。输出结果中会包含errno所对应的错误消息。

如果运行该示例,将会输出如下信息:

SQLite error: no such table: non_existing_table
System error: 2
System error message: No such file or directory

可以看到,该示例中由于执行了一个不存在的表查询语句,会导致系统错误号为2(ENOENT),表示找不到指定的文件或目录。

51.sqlite3_table_column_metadata

功能:获取表中某一列的信息,包括列类型、是否为主键等信息。

函数的原型如下:

int sqlite3_table_column_metadata(
  sqlite3 *db,               /* 数据库连接 */
  const char *zDbName,       /* 数据库名称,空表示当前数据库 */
  const char *zTableName,    /* 表名称 */
  const char *zColumnName,   /* 列名称,如果空则返回所有列 */
  char const **pzDataType,   /* 返回数据类型 */
  char const **pzCollSeq,    /* 返回排序规则的名称 */
  int *pNotNull,             /* 返回是否是NOT NULL的标志 */
  int *pPrimaryKey,          /* 返回是否是主键的标志 */
  int *pAutoinc              /* 返回是否是自增列的标志 */
);

各个参数的含义如下:

- db:数据库连接句柄。
- zDbName:表所在的数据库的名称,为NULL表示当前连接的数据库。
- zTableName:表的名称。
- zColumnName:列的名称,可以为一个空指针,如果为NULL,则将返回指定表的所有列的信息。
- pzDataType:如果不为NULL,将得到列的类型信息的指针。
- pzCollSeq:如果不为NULL,则得到列的排序规则名称。
- pNotNull:如果不为NULL,则得到非空列的标志,如果列为非空,则为1,否则为0。
- pPrimaryKey:如果不为NULL,则得到主键的标志。如果列是主键,则为1,否则为0。
- pAutoinc:如果不为NULL,则得到列是否为自增的标志。如果列为自增长,则为1,否则为0。

下面是一个示例:

#include <sqlite3.h>
#include <stdio.h>
int main() {
    sqlite3 *db;
    sqlite3_open(":memory:", &db);
    sqlite3_exec(db, "CREATE TABLE test (id INTEGER PRIMARY KEY AUTOINCREMENT, value TEXT NOT NULL)", NULL, NULL, NULL);
    const char *dataType;
    const char *collSeq;
    int notNull;
    int primaryKey;
    int autoinc;
    sqlite3_table_column_metadata(db, NULL, "test", "id", &dataType, &collSeq, &notNull, &primaryKey, &autoinc);
    printf("id info:\ndataType=%s\ncollSeq=%s\nnotNull=%d\nprimaryKey=%d\nautoinc=%d\n", dataType, collSeq, notNull, primaryKey, autoinc);
    sqlite3_table_column_metadata(db, NULL, "test", "value", &dataType, &collSeq, &notNull, &primaryKey, &autoinc);
    printf("value info:\ndataType=%s\ncollSeq=%s\nnotNull=%d\nprimaryKey=%d\nautoinc=%d\n", dataType, collSeq, notNull, primaryKey, autoinc);
    sqlite3_close(db);
    return 0;
}

该示例中我们创建了一张包含两个列的表,其中id列为主键、INT类型、自增,value列为TEXT类型、非空。

在程序中我们使用sqlite3_table_column_metadata()函数获取id列和value列的相关信息,这些信息分别包括:数据类型、排序规则、是否为非空列、是否为主键、是否为自增列值。

输出结果如下:

id info:
dataType=INTEGER
collSeq=BINARY
notNull=0
primaryKey=1
autoinc=1
value info:
dataType=TEXT
collSeq=BINARY
notNull=1
primaryKey=0
autoinc=0

我们可以看到,id列是主键、INT类型、自增,而value列是TEXT类型、非空。

52.sqlite3_total_changes与sqlite3_total_changes64

函数功能:获取自数据库连接打开以来所做的修改总数,即INSERT、UPDATE和DELETE所影响的总行数。两个函数的主要区别在于,sqlite3_total_changes返回一个int类型的值,而sqlite3_total_changes64返回一个int64类型的值。

函数的原型如下:

int sqlite3_total_changes(sqlite3*);
sqlite3_int64 sqlite3_total_changes64(sqlite3*);

参数是一个指向sqlite3结构体的指针,返回值是一个表示自连接建立以来所做的修改次数的整数值(或64位整数值)。

下面是一个示例,展示如何计算自打开数据库以来所做的更改总数:

#include <sqlite3.h>
#include <stdio.h>
int main() {
    sqlite3 *db;
    sqlite3_open(":memory:", &db);
    sqlite3_exec(db, "CREATE TABLE test (id INTEGER PRIMARY KEY, value TEXT)", NULL, NULL, NULL);
    sqlite3_exec(db, "INSERT INTO test (id, value) VALUES (1, 'hello')", NULL, NULL, NULL);
    sqlite3_exec(db, "UPDATE test SET value = 'world' WHERE id = 1", NULL, NULL, NULL);
    sqlite3_exec(db, "DELETE FROM test WHERE id = 1", NULL, NULL, NULL);
    int changes = sqlite3_total_changes(db);
    printf("Total changes: %d\n", changes);
    sqlite3_int64 changes64 = sqlite3_total_changes64(db);
    printf("Total changes (int64): %lld\n", changes64);
    sqlite3_close(db);
    return 0;
}

在该示例中,我们创建了一个test表,并进行了一些INSERT、UPDATE和DELETE操作。然后我们使用sqlite3_total_changes()和sqlite3_total_changes64()函数获取自打开数据库以来所做的更改总数。输出结果如下:

Total changes: 3
Total changes (int64): 3
可以看到,该示例中自打开数据库以来所做的更改总数为3条记录。

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

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

相关文章

STL:List从0到1

&#x1f389;个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名乐于分享在学习道路上收获的大二在校生 &#x1f648;个人主页&#x1f389;&#xff1a;GOTXX &#x1f43c;个人WeChat&#xff1a;ILXOXVJE &#x1f43c;本文由GOTXX原创&#xff0c;首发CSDN&…

uniapp开发微信小程序调用打电话

在使用uniapp开发微信小程序的时候&#xff0c;经常需要调用打电话功能。 下面我们来讲解一下如何实现该功能&#xff0c;效果图请看下图&#xff1a; 代码部分&#xff1a; <!-- h5部分 --><button click"playphone()"></button><!-- JS部分 …

代码随想录day21(1)二叉树:平衡二叉树(leetcode110)

题目要求&#xff1a;判断一棵树是否为平衡二叉树 思路&#xff1a;递归地比较左右子树&#xff0c;只要有一棵子树不满足条件就说明这棵树不是平衡二叉树。本题采用迭代法较为复杂。 leetcode实战&#xff1a; 代码实现&#xff1a; 递归&#xff1a; 迭代&#xff1a;

【WebAssembly】WebAssembly概念介绍和在js中使用

简言 记录下WebAssembly的概念和在JavaScript中的使用方法。 WebAssembly官网 WebAssembly WebAssembly &#xff08;缩写为 Wasm&#xff09;是一种二进制指令格式&#xff0c;用于基于堆栈的虚拟机。Wasm 被设计为编程语言的可移植编译目标&#xff0c;可在网络上部署客户…

爬虫逆向sm3和sm4 加密 案例

注意&#xff01;&#xff01;&#xff01;&#xff01;某XX网站逆向实例仅作为学习案例&#xff0c;禁止其他个人以及团体做谋利用途&#xff01;&#xff01;&#xff01; 案例--aHR0cDovLzExMS41Ni4xNDIuMTM6MTgwODgvc3Vic2lkeU9wZW4 第一步&#xff1a;分析页面和请求方式 …

代码随想录算法训练营第39天 | 62.不同路径 , 63. 不同路径 II

动态规划章节理论基础&#xff1a; https://programmercarl.com/%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92%E7%90%86%E8%AE%BA%E5%9F%BA%E7%A1%80.html 62.不同路径 题目链接&#xff1a;https://leetcode.cn/problems/unique-paths/ 思路&#xff1a; 动规五部曲&#xff1a…

实战Python Socket编程:开发多用户聊天应用

实战Python Socket编程&#xff1a;开发多用户聊天应用 Python Socket 编程概述什么是Socket编程&#xff1f;Socket编程的应用场景Socket编程的重要性基本概念 环境准备Python版本必要的库开发环境配置调试工具 基本Socket编程创建Socket绑定Socket到端口监听连接接受连接发送…

基于C++的反射功能

需求&#xff1a; 利用C的发射机制&#xff0c;实现根据字符串创建实例对象。 代码&#xff1a; #ifndef OBJECT_H #define OBJECT_H#include <string> #include <map>typedef void* (*Constructor)();class CObjectFactory { public:static void registerClass…

Spring Boot轻松整合Minio实现文件上传下载功能【建议收藏】

一、Linux 安装Minio 安装 在/root/xxkfz/soft目录下面创建文件minio文件夹&#xff0c;进入minio文件夹&#xff0c;并创建data目录&#xff1b; [rootxxkfz soft]# mkdir minio [rootxxkfz soft]# cd minio [rootxxkfz minio]# mkdir data执行如下命令进行下载 [rootxxkf…

python基础——字符串的常见操作方法【下标索引,index,count,len,replace,split,strip】

&#x1f4dd;前言&#xff1a; 字符串是一种有序的&#xff0c;允许重复字符串存在的&#xff0c;不可修改的序列 这篇文章主要总结一下python中有关字符串的部分相关知识&#xff0c;以及字符串的常见操作方法&#xff1a; 1&#xff0c;和其他序列极其类似的操作方法 2&…

Three 材质纹理 (总结三)

THREE.MeshLambertMaterial&#xff08;网格 Lambert 材质&#xff09; 该材质使用基于非物理的Lambertian模型来计算反射率。可以用来创建暗淡的并不光亮的表面&#xff0c;该材质非常易用&#xff0c;而且会与场景中的光源产生反应。 MeshLambertMaterial属性 # .color : …

mysql中用逗号隔开的某字段,如何判断其他表的字段值是否在这个字段中

因为要增加需求&#xff0c;需要将线上表中老数据&#xff0c;修改为新数据的规则。 线上两张表&#xff0c;sequence_number中is_use有3作废、2到期状态&#xff0c;需要根据这个状态和school_ai_authorization中的is_deleted修改新增的state字段。 sequence_number表结构&…

数据分析实战-Python实现博客评论数据的情感分析

数据分析实战-Python实现博客评论数据的情感分析 学习建议SnowNLP基础什么是SnowNLP&#xff1f;SnowNLP情感分析 SnowNLP使用SnowNLP安装情感分析中文分词关键词提取拼音、词性标准 SnowNLP实战-博客评论数据的情感分析数据准备数据获取数据分析 总结 学习建议 现在很多网站、…

关于振弦采集仪的应用编写

instruction&#xff1a; 1、本应用基于深圳市安传物联科技有限公司所生产的八通道振弦变送器产品。该产品为MAX485 信号的变送设备&#xff0c; 并以Modbus协议输出。 2、本应用采用python语言编写。 功能实现&#xff1a; 1、发送&#xff1a; 01 03 10 00 00 02 C0 CB并…

JVM之调优(一)

背景&#xff1a;生产环境由于堆内存较大&#xff0c;fullgc 垃圾回收导致程序卡顿问题&#xff08;假死&#xff09; 目录 一、程序卡顿导致的影响 前端页面空白后端数据重复 二、解决方法 降低堆内存大小使用合适的垃圾回收器&#xff08;可以尝试&#xff0c;还未进行测试…

【python】爬取杭州市二手房销售数据做数据分析【附源码】

一、背景 在数据分析和市场调研中&#xff0c;获取房地产数据是至关重要的一环。本文介绍了如何利用 Python 中的 requests、lxml 库以及 pandas 库&#xff0c;结合 XPath 解析网页信息&#xff0c;实现对链家网二手房销售数据的爬取&#xff0c;并将数据导出为 Excel 文件的过…

捋顺【反函数求导】

设 d y d x f ( x ) 则 d x d y 1 f ( x ) 以 y t a n x 为 例 &#xff0c; d y / d x s e c 2 x , d x / d y 1 s e c 2 x c o s 2 x 到 此 为 止 &#xff0c; 似 乎 难 以 推 导 &#xff0c; 但 是 假 如 用 t a n x ( 也 就 是 y ) 将 c o s 2 x 表 示 出 来 &…

jenkins容器中安装python遇到问题

在Jenkins容器中安装配置Python时遇到问题 执行./configure --prefix/opt/python3/时遇到configure: error: no acceptable C compiler found in $PATH 这个问题就是缺少gcc编译环境。将gcc安装上即可&#xff1a; yum install -y gcc##前提是容器里的系统是cenos才可以&#…

实在智能Agent——RPA终极进化方向

RPA技术备受瞩目&#xff0c;它通过“机器人”自动化了人力执行的重复性、低复杂度任务&#xff0c;解放了员工并降低了企业成本。RPA机器人全天候运行&#xff0c;避免人为错误&#xff0c;高效处理任务&#xff0c;成为处理事务、操作数据、回应查询的理想选择。在管理后台&a…

易方达产品亏损仍存,“老鼠仓”阴影犹在,如何突出重围?

近日&#xff0c;易方达基金宣布易方达沪深300 ETF跻身“千亿规模ETF”行列&#xff0c;成为国内“ETF千亿俱乐部”的第三位成员。截至3月8日&#xff0c;该基金的规模增长112.21亿元&#xff0c;涨幅9.45%&#xff0c;规模增量在10亿以上的股票型ETF产品中排名第一。 回望202…