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

news2024/11/19 6:32:53

 返回目录: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条记录。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

相机sd卡照片删除后数据恢复,相机sd卡中的照片被删除后如何恢复数据

当我们使用相机拍摄照片时&#xff0c;有时会不小心删除了一些重要的照片。这可能是因为误操作、SD卡故障或者其他原因。无论是珍贵的照片、还是重要的工作文件&#xff0c;被删除后&#xff0c;我们往往会感到焦虑和失望。相机sd卡中的照片被删除后如何恢复数据&#xff1f;幸…

Windows下安装双版本Python环境安装

前言 根据自己电脑系统选择所需版本进行下载&#xff0c;本次以Windows11环境为展示案例 本机系统查看 例如Windows11&#xff0c;进入系统即可查看本机信息 Python环境安装 Python下载 Python 3 下载 Python 2 下载&#xff0c;在历史版本中找到Python 2 最新版进行下载…

YOLOv7-Openvino和ONNXRuntime推理【CPU】

纯检测系列&#xff1a; YOLOv5-Openvino和ONNXRuntime推理【CPU】 YOLOv6-Openvino和ONNXRuntime推理【CPU】 YOLOv8-Openvino和ONNXRuntime推理【CPU】 YOLOv7-Openvino和ONNXRuntime推理【CPU】 YOLOv9-Openvino和ONNXRuntime推理【CPU】 跟踪系列&#xff1a; YOLOv5/6/7-O…

vscode 生成树状图工具:project-tree

按下快捷键“CtrlShiftP”, 在弹框中输入 Project Tree&#xff0c;然后敲回车即会在根目录自动生成README.md&#xff08;如果之前没有的话&#xff09;。

[题解]无厘头题目——无聊的军官

这道题非常无厘头&#xff01; 题目描述&#xff1a; 每个学年的开始&#xff0c;高一新生们都要进行传统的军训。今年有一个军训教官十分奇怪&#xff0c;他为了测试学员们的反应能力&#xff0c;每次吹哨后学员们都会变换位置。每次左数第I位学员都会站到第ai个位置&#x…

谷歌的后量子密码学威胁模型

1. 引言 若现在不使用量子安全算法来加密数据&#xff0c;能够存储当前通信的攻击者最快十年内就能对其解密。这种先存储后解密的攻击是当前采用后量子密码学 (post-quantum cryptography&#xff0c;PQC) 背后的主要动机&#xff0c;但其他未来的量子计算威胁也需要一个深思熟…

Linux下Arthas(阿尔萨斯)的简单使用-接口调用慢排查

使用环境 k8s容器内运行了一个springboot服务&#xff0c;服务的启动方法是main()方法 下载并启动 arthas curl -O https://arthas.aliyun.com/arthas-boot.jar java -jar arthas-boot.jar选择应用 java 进程 就一个进程org.apache.catalina.startup.Bootstrap&#xff0c;输…

Unity PS5开发 天坑篇 之 申请开发者与硬件部署01

腾了好几天终于把PS5开发机调试部署成功, 希望能帮到国内的开发者, 主机游戏PlayStation/Nintendo Switch都是比较闭塞的&#xff0c;开发者账号是必须的。 开发环境有两个部分&#xff0c;一是DEV Kit 开发机, TEST Kit测试机两部分组成&#xff0c;二是Unity的支持库(安装后…

Android的三种动画详解(帧动画,View动画,属性动画)

Android的三种动画详解&#xff08;帧动画、View动画、属性动画&#xff09;_android动画效果大全-CSDN博客 1、帧动画 缺点是&#xff1a;占用内存较高&#xff0c;播放的是一帧一帧的图片&#xff0c;很少使用。 顺序播放预先定义的图片&#xff0c;类似于播放视频。 步骤…

数据结构 第3章:栈与队列

文章目录 1. 栈1.1 栈的基本概念1.2 栈的基本操作1.3 栈的顺序存储实现1.4 栈的链式存储实现 2. 队列2.1 队列的基本概念2.2 队列的基本操作2.3. 队列的顺序存储实现2.4 队列的链式存储实现2.5 双端队列 3. 栈与队列的应用3.1 栈在括号匹配中的应用3.2 栈在表达式求值中的应用3…

k8s的pod和svc相互访问时网络链路解析

k8s的pod和svc相互访问时网络链路解析 1. k8s环境中pod相互访问1.1. k8s中pod相互访问的整体流程1.2. k8s的相同机器的不同pod相互访问1.3. k8s的不同机器的不同pod相互访问 2. k8s访问svc2.1 nat操作2.2 流量进入到后端pod 3. 疑问和思考3.1 访问pod相互访问为什么不用做nat?…

【Linux】从零开始认识进程 — 前篇

我从来不相信什么懒洋洋的自由。我向往的自由是通过勤奋和努力实现的更广阔的人生。。——山本耀司 从零开始认识进程 1 认识冯诺依曼体系2 操作系统3 进程3.1 什么是进程&#xff1f;&#xff1f;&#xff1f;3.2 进程管理PCB 3.3 Linux中的进程深入理解 3.4 进程创建总结 送给…

【vue baidu-map】实现百度地图展示基地,鼠标悬浮标注点展示详细信息

实现效果如下&#xff1a; 自用代码记录 <template><div class"map" style"position: relative;"><baidu-mapid"bjmap":scroll-wheel-zoom"true":auto-resize"true"ready"handler"><bm-mar…

JVMJava虚拟机

JVM的内存区域 程序计数器&#xff1a; 字节码解释器通过改变程序计数器来依次读取指令&#xff0c;从而实现代码的流程控制&#xff0c;如&#xff1a;顺序执行、选择、循环、异常处理。 在多线程的情况下&#xff0c;程序计数器用于记录当前线程执行的位置&#xff0c;从而当…

python—gui-计算图像像素两点间距离

代码&#xff1a; import tkinter as tk from tkinter import ttkdef create_gui():# 创建Tkinter窗口root tk.Tk()# 设置窗口标题root.title("显示图片")# 图片文件路径image_path path_to_your_image.jpg# 加载图片img load_image(image_path)# 创建标签&#…

产品推荐 - ALINX XILINX FPGA开发板 Artix-7 XC7A100T-2FGG484I

01开发板介绍 此款开发板采用核心板扩展板的模式&#xff0c;方便用户对核心板的二次开发利用。FPGA使用的是Xilinx公司的ARTIX-7系列的芯片&#xff0c;型号为XC7A100T-2FGG484I。在核心板使用了2片MICRON公司的MT41J256M16HA-125 DDR3芯片&#xff0c;组合成32bit的数据总线…

联想拯救者刃7000K2024游戏电脑主机仅售6999元

这款联想拯救者刀锋7000K 2024游戏电脑主机在京东促销中售价仅为6999元&#xff0c;相比原价7499元有相当大的折扣。 这是一款功能强大的游戏电脑&#xff0c;配备了全新的 15-14400(F) 处理器和 RTX™ 4060 显卡&#xff0c;以及 16GB DDR5 内存和 1TB 固态硬盘。 外观方面&a…

STL_vector简化模拟—详解深层次深拷贝问题

文章目录 迭代器框架和成员变量基础成员函数容量相关的成员函数关于深拷贝中的深拷贝问题operator[ ]重载和内容修改函数类模板内的嵌套类型全部代码 根据原码看出vector的成员并不像string类的一个指针加一个size和一个capacity。 而是三个指针&#xff0c;_start , _finish ,…

IntelliJ IDEA 面试题及答案整理,最新面试题

IntelliJ IDEA中的插件系统如何工作&#xff1f; IntelliJ IDEA的插件系统工作原理如下&#xff1a; 1、插件架构&#xff1a; IntelliJ IDEA通过插件架构扩展其功能&#xff0c;插件可以添加新的功能或修改现有功能。 2、安装和管理&#xff1a; 通过IDEA内置的插件市场下载…

【海贼王的数据航海】排序——直接选择排序|堆排序

目录 1 -> 选择排序 1.1 -> 基本思想 1.2 -> 直接选择排序 1.2.1 -> 代码实现 1.3 -> 堆排序 1.3.1 -> 代码实现 1 -> 选择排序 1.1 -> 基本思想 每一次从待排序的数据元素中选出最小(或最大)的一个元素&#xff0c;存放在序列的起始位置&…