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条记录。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL数据库-MySQL基础-下篇-函数、约束、多表查询、事务

文章目录 函数一、字符串函数练习 二、数值函数三、日期函数四、流程函数总结 约束概述约束演示外键约束概念语法删除/更新行为 总结 多表查询多表关系一对多&#xff08;多对一&#xff09;多对多一对一 多表查询概述内连接外连接自连接*联合查询-union, union all子查询标量子…

LeetCode # 199. 二叉树的右视图

199. 二叉树的右视图 题目 给定一个二叉树的 根节点 root&#xff0c;想象自己站在它的右侧&#xff0c;按照从顶部到底部的顺序&#xff0c;返回从右侧所能看到的节点值。 示例 1: 输入: [1,2,3,null,5,null,4] 输出: [1,3,4] 示例 2: 输入: [1,null,3] 输出: [1,3] 示例 3…

js实现hash路由原理

一、简单的上下布局&#xff0c;点击左侧导航&#xff0c;中间内容跟对变化&#xff0c;主要技术使用js检测路由的onhashchange事件 效果图 二、话不多说&#xff0c;直接上代码 <!DOCTYPE html> <html lang"zh"><head><meta charset"…

操作系统面经-什么是操作系统?

通过以下四点可以概括操作系统到底是什么&#xff1a; 操作系统&#xff08;Operating System&#xff0c;简称 OS&#xff09;是管理计算机硬件与软件资源的程序&#xff0c;是计算机的基石。操作系统本质上是一个运行在计算机上的软件程序 &#xff0c;主要用于管理计算机硬…

【Unity】获取游戏对象或组件的常用方法

前言 在Unity开发过程中&#xff0c;我们经常需要获取组件&#xff0c;那么在Unity里如何获取组件呢&#xff1f; 一、获取游戏对象 1.GameObject.Find GameObject.Find 是通过物体的名称获取对象的 所以会遍历当前整个场景&#xff0c;效率较低 而且只能获取激活状态的物体…

P2799 国王的魔镜

题目链接&#xff1a;国王的魔镜 - 洛谷 题目难度&#xff1a;普及- 涉及知识点&#xff1a;判断回文 题意&#xff1a; 分析&#xff1a;先判断是否是2的倍数&#xff0c;再判断回文 AC代码&#xff1a; #include<bits/stdc.h> using namespace std; char a[10000…

VMWare虚拟机使用openmediavault搭建NAS服务器完整步聚

下载: gopenmediavault - The open network attached storage solution 下载好openmediavault的ISO镜像后,打开虚拟机并安装 系统类型选择Debian 启动虚拟机并安装openmediavault 选择中文 地区选中国 键盘配置选汉语 开始安装 配置网络信息 配置root密码 确认密码 系统安装中…

汽车功能安全整体方法

摘 要 ISO26262道路车辆功能安全标准已经制定实践了多年&#xff0c;主要目标是应对车辆的电子和电气&#xff08;E/E&#xff09;系统失效。该方法践行至今&#xff0c;有些系统功能安全方法已经成熟&#xff0c;例如电池管理系统&#xff08;BMS&#xff09;&#xff0c;并且…

掌握C语言结构体,开启编程新世界

✨✨欢迎&#x1f44d;&#x1f44d;点赞☕️☕️收藏✍✍评论 个人主页&#xff1a;秋邱博客 所属栏目&#xff1a;C语言 &#xff08;感谢您的光临&#xff0c;您的光临蓬荜生辉&#xff09; 前言 前面我们也涉及到了结构体的讲解&#xff0c;但是只是粗略的讲了一下。 接下…

SpringBoot+Vue项目(后端项目搭建 + 添加家居)

文章目录 1.使用版本控制管理该项目1.创建远程仓库2.克隆到本地 2.后端项目环境搭建1.创建一个maven项目2.删除不必要的文件夹3.pom.xml文件引入依赖4.application.yml 配置数据源&#xff08;注意&#xff0c;数据库名还没写&#xff09;5.com/sun/furn/Application.java 编写…

python中医学习服务管理系统flask-django-php-nodejs

随着世界经济信息化、全球化的到来和互联网的飞速发展&#xff0c;推动了各行业的改革。若想达到安全&#xff0c;快捷的目的&#xff0c;就需要拥有信息化的组织和管理模式&#xff0c;建立一套合理、动态的、交互友好的、高效的中医学习服务管理系统。当前的信息管理存在工作…

JAVA后端调用OpenAI接口 实现打字机效果(SSE)

SSE SSE&#xff08;Server-Sent Events&#xff0c;服务器发送事件&#xff09;是一种基于HTTP协议的通信技术&#xff0c;它允许服务器持续地将数据推送给客户端&#xff0c;而无需客户端发起请求。这种通信方式通常用于实时性要求较高的场景&#xff0c;如实时更新、通知、或…

Python Flask框架 -- 模版继承

一个网站中&#xff0c;大部分网页的模块是重复的&#xff0c;比如顶部的导航栏&#xff0c;底部的备案信息。如果在每个页面中都重复的去写这些代码&#xff0c;会让项目变得臃肿&#xff0c;提高后期维护成本。比较好的做法是&#xff0c;通过模板继承&#xff0c;把一些重复…

STM32-Flash闪存

简介 STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过闪存存储器接口&#xff08;外设&#xff09;可以对程序存储器和选项字节进行擦除和编程。 读写Flash的用途 1.利用程序存储器的剩余空间来保存掉电不丢失的用户数据。 2.通过在程序中…

CVE-2024-24112 XMall后台管理系统 SQL 注入漏洞分析

------作者本科毕业设计项目 基于 Spring Boot Vue 开发而成...... [Affected Component] /item/list /item/listSearch /sys/log /order/list /member/list (need time-based blind injection) /member/list/remove 项目下载地址 Exrick/xmall: 基于SOA架构的分布式…

Django日志(一)

一、概念与配置 1.1、概述 日志是程序员经常在代码中使用快速和方便的调试工具。它在调试方面比print更加的优雅和灵活 而且日志记录对于调试很有用,可以提供更多,更好的结构化,有关应用程序的状态和运行状况的信息 Django框架的日志通过python内置的logging模块实现的,可…

Elasticsearch:让你的 Elasticsearch 索引与 Python 和 Google Cloud Platform 功能保持同步

作者&#xff1a;来自 Elastic Garson Elasticsearch 内的索引 (index) 是你可以将数据存储在文档中的位置。 在使用索引时&#xff0c;如果你使用的是动态数据集&#xff0c;数据可能会很快变旧。 为了避免此问题&#xff0c;你可以创建一个 Python 脚本来更新索引&#xff0…

每日OJ题_牛客WY3 小易的升级之路(IO型OJ)

目录 牛客WY3 小易的升级之路 解析代码 牛客WY3 小易的升级之路 小易的升级之路_牛客题霸_牛客网 解析代码 #include <iostream> #include <vector> using namespace std;int getVal(int a, int b) {if (a > b)swap(a, b);for (int i a; i > 1; --i){if…

科研绘图一:箱线图(添加贝赛尔曲线)

R语言绘图系列—箱线图贝赛尔曲线 &#xff08;一&#xff09;: 科研绘图一&#xff1a;箱线图&#xff08;添加贝赛尔曲线&#xff09; 文章目录 R语言绘图系列---箱线图贝赛尔曲线&#xff08;一&#xff09;: 科研绘图一&#xff1a;箱线图&#xff08;添加贝赛尔曲线&…

【MySQL】MySQL用户管理

文章目录 一、用户1.用户信息2.创建用户3.删除用户4.修改用户密码 二、数据库的权限1.给用户授权2.回收权限 一、用户 如果我们只能使用root用户&#xff0c;这样存在安全隐患。这时&#xff0c;就需要使用MySQL的用户管理。 1.用户信息 我们安装mysql之后&#xff0c;会自动…