SQLiteC/C++接口详细介绍之sqlite3类(十五)
返回目录:SQLite—免费开源数据库系列文章目录
上一篇:SQLiteC/C++接口详细介绍之sqlite3类(十四)
下一篇:SQLiteC/C++接口详细介绍之sqlite3类(十六)

47.sqlite3_set_authorizer
用法:在SQLite的访问控制中注册一个授权回调函数,用于限制或禁止某些SQL语句的执行。
函数原型如下:
int sqlite3_set_authorizer(sqlite3*,int (*xAuth)(void*,int,const char*,const char*,const char*,const char*),void* pUserData
);
- 第一个参数是数据库连接的指针
- 第二个参数是一个回调函数指针,该回调函数是访问授权的核心,用于审批或拒绝SQL语句的执行
- 第三个参数是用户带的指针,该指针可以在回调函数中使用
回调函数的原型如下:
int my_authorizer_callback(void* pArg, int eCode, const char* zDb, const char* zPtr1, const char* zPtr2, const char* zPtr3);
- 第一个参数是user-data指针
- 第二个参数是一个SQLITE_AUTH_*常量,指示某个SQL语句属于何种类型操作,比如是SELECT、INSERT等等。
- 后面的参数zDb,zPtr1,zPtr2,zPtr3指向与用户访问有关的数据库、表、列或者索引的名称。这四个参数不一定全部被用到,取决于具体的SQL语句类型。
返回值如下:
- 如果回调函数返回SQLITE_DENY,则表示不允许执行这条SQL语句。
- 如果回调函数返回SQLITE_IGNORE,则表示通过SQL语句的执行,但是不允许修改具体的数据库数据。
- 如果回调函数返回SQLITE_OK,则表示允许执行这条SQL语句。
下面是一个简单的示例,回调函数阻止DROP TABLE、DROP VIEW和DELETE语句的执行:
#include <sqlite3.h>
#include <stdio.h>
int authorizer_callback(void* pArg, int eCode, const char* zDb, const char* zPtr1, const char* zPtr2, const char* zPtr3) {if (eCode == SQLITE_DROP_TABLE || eCode == SQLITE_DROP_VIEW || eCode == SQLITE_DELETE) {printf("Unauthorized Operation\n");return SQLITE_DENY;}return SQLITE_OK;
}
int main() {sqlite3 *db;sqlite3_open(":memory:", &db);sqlite3_set_authorizer(db, authorizer_callback, NULL);sqlite3_exec(db, "CREATE TABLE test (id INTEGER PRIMARY KEY, value TEXT)", NULL, NULL, NULL);sqlite3_exec(db, "INSERT INTO test VALUES (1, 'hello')", NULL, NULL, NULL);sqlite3_exec(db, "DELETE FROM test WHERE id = 1", NULL, NULL, NULL);sqlite3_exec(db, "DROP TABLE test", NULL, NULL, NULL);sqlite3_close(db);return 0;
}
当执行DROP TABLE、DROP VIEW和DELETE语句时,回调函数将阻止执行,并输出"Unauthorized Operation"。需要注意的是,要在执行SQL语句之前设置授权回调函数,否则将无法生效。
48.sqlite3_set_clientdata
sqlite3_set_clientdata函数用于在SQLite的会话中为客户端数据设置指针,该指针可以在SQLite操作期间使用,并永久存储。这个指针通常被用于存储客户端上下文数据,比如在回调函数中访问。
函数原型如下:
void sqlite3_set_clientdata(sqlite3_context*, void*);
函数使用较为简单,第一个参数是指向sqlite3_context结构体的指针,这个指针通常由回调函数提供。第二个参数是一个void类型的指针,这个指针将与sqlite3_context结构体关联。
下面是一个示例,展示如何在sqlite3_create_function()回调函数中使用sqlite3_set_clientdata()来存储客户端上下文数据:
#include <sqlite3.h>
#include <stdio.h>
static void my_function(sqlite3_context *context,int argc,sqlite3_value **argv
) {int count = (int)(intptr_t)sqlite3_get_auxdata(context, 0); // 从上下文中获取计数器count++; // 计数器加1sqlite3_set_auxdata(context, 0, (void*)(intptr_t)count); // 将计数器放回上下文中sqlite3_result_int(context, count); // 返回计数器值
}
int main() {sqlite3 *db;sqlite3_open(":memory:", &db);sqlite3_create_function(db, "my_function", -1, SQLITE_ANY, NULL, my_function, NULL, NULL);void *pUserData = malloc(sizeof(int));*(int*)pUserData = 0;sqlite3_set_auxdata(db, 0, pUserData); // 将计数器存储在数据库连接中sqlite3_context *context = sqlite3_malloc(sizeof(sqlite3_context));sqlite3_set_clientdata(context, db); // 将数据库连接与上下文关联sqlite3_exec(db, "SELECT my_function()", NULL, NULL, NULL);sqlite3_exec(db, "SELECT my_function()", NULL, NULL, NULL);int count = (int)(intptr_t)sqlite3_get_auxdata(db, 0);printf("function called %d times\n", count);sqlite3_close(db);return 0;
}
该示例通过sqlite3_set_auxdata()函数在数据库连接中存储一个计数器。每次调用my_function()回调函数时,它将自加该计数器并返回该计数器。用sqlite3_set_clientdata()函数将上下文与数据库连接关联。最后,从数据库连接中获取计数器并输出结果。
49.sqlite3_set_last_insert_rowid
sqlite3_set_last_insert_rowid函数用于手动设置最后插入的行ID。通常情况下,SQLite会自动维护最后插入的行ID,无需手动设置。但是,有时候可能需要在想要插入的ID不是递增的情况下手动指定插入行ID。
函数原型如下:
void sqlite3_set_last_insert_rowid(sqlite3*, sqlite3_int64);
第一个参数是指向sqlite3结构体的指针,第二个参数是一个sqlite3_int64类型的整数,代表要设置的最后插入的行ID。
下面是一个示例,展示如何手动设置最后插入的行ID:
#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_int64 rowid = 10;sqlite3_set_last_insert_rowid(db, rowid); // 设置最后插入的行IDsqlite3_exec(db, "INSERT INTO test (id, value) VALUES (11, 'hello')", NULL, NULL, NULL);rowid = sqlite3_last_insert_rowid(db); // 获取最后插入的行IDprintf("last_insert_rowid = %lld\n", rowid);sqlite3_close(db);return 0;
}
在该示例中,我们使用sqlite3_set_last_insert_rowid()函数手动设置了最后插入的行ID为10,然后插入一条ID为11的数据。最后,我们获取最后插入的行ID并将其输出。输出结果为:last_insert_rowid = 10。
相关文章:
SQLiteC/C++接口详细介绍之sqlite3类(十五)
返回目录:SQLite—免费开源数据库系列文章目录 上一篇:SQLiteC/C接口详细介绍之sqlite3类(十四) 下一篇:SQLiteC/C接口详细介绍之sqlite3类(十六) 47.sqlite3_set_authorizer 用法ÿ…...
每日三个JAVA经典面试题(十八)
1.volatile 关键字的作用 在Java中,volatile关键字用于声明变量,以确保该变量的更新对所有线程都是可见的,即当一个线程修改了一个volatile变量的值,这个新值对于其他线程来说是立即得知的。volatile关键字有两个主要作用&#x…...
RPC 和 序列化
RPC 1 RPC调用流程 1.1 clerk客户端调用远程服务 Clerk::PutAppend() raftServerRpcUtil::PutAppend() raftServerRpcUtil是client与kvserver通信的入口, 包含kvserver功能的一对一映射:Get/PutAppend,通过stub对象——raftKVRpcProctoc:…...
【原创】三十分钟实时数据可视化网站前后端教程 Scrapy + Django + React 保姆级教程向
这个本来是想做视频的,所以是以讲稿的形式写的。最后没做视频,但是觉得这篇文还是值得记录一下。真的要多记录,不然一些不常用的东西即使做过几个月又有点陌生了。 文章目录 爬虫 SCRAPYxpath 后端 DJANGO前端 REACT Hello大家好这里是小鱼&a…...
MySQL的备份
为什么要备份: 1.保证重要的数据不丢失 2.数据转移 MySQL数据库备份的方式: 1.直接拷贝物理文件 2.在可视化工具中手动导出 (1)在想要导出的表或者数据库中,右键,选择备份或导出 使用命令行导出 MyS…...
Linux 磁盘的一生
注意:实验环境都是使用VMware模拟 磁盘接口类型这里vm中是SCSI,扩展sata,ide(有时间可以看看或者磁盘的历史) 总结:磁盘从有到无—类似于建房子到可以住 ————————————————————————————————————…...
C#配置连接数据库字段
在Web.config文件中 添加如下配置 <!--连接数据库字段--><connectionStrings><add name"sql" connectionString"server.;uidsa;pwd8888;databaseArticleWebSite" /></connectionStrings>...
QCOM和其他常见芯片平台术语缩写
1 QCOM 1.1 General Qualcomm: Quality Communications ALSA DCP:ALSA由DAI、Codec、Platform三部分组成 ALSA TLV:Type-Length-Value Alternative Mode: 替代模式 ANC:Automatic Noise Canceller ASM: Anntena Switch Module AT:…...
css页面布局
CSS属性书写顺序(重点) 建议遵循以下顺序: 布局定位属性:display / position/ float / clear / visibility / overflow(建议display第一个写,毕竟关系到模式) 自身属性:width / height / margin / padding / border / background…...
6、Design Script之列表
Range 在DesignScript中,Range是从起点到终点的一系列数字,使用指定的步距(间距类型),并有以下的初始化方法: start..end..step; start..end..#amount; start..end..~approximate; Range可以是数字的,也可以是字母的。 字母范围因大小写而异。 开始,结束. .#数量范围(…...
Mysql数据库的多实例部署
mysql多实例部署 先进行软件下载 上传二进制格式的mysql软件包 [rootcjy ~]# ls anaconda-ks.cfg mysql-8.0.35-linux-glibc2.28-x86_64.tar.xz配置用户和组并解压二进制程序至/usr/local下 创建用户和组 [rootcjy ~]# useradd -r -s /sbin/nologin -M mysql解压软件至/usr…...
陈巍:Sora大模型技术精要万字详解(上)——原理、关键技术、模型架构详解与应用
目录 收起 1 Sora的技术特点与原理 1.1 技术特点概述 1.2 时间长度与时序一致性 1.3 真实世界物理状态模拟 1.4 Sora原理 1.4.1扩散模型与单帧图像的生成 1.4.2 Transformer模型与连续视频语义的生成 1.4.3 从文本输入到视频生成 2 Sora的关键技术 2.1 传统文生图技…...
JS原型和原型链的理解
原型链图,图中Parent是构造函数,p1是通过Parent实例化出来的一个对象 前置知识 js中对象和函数的关系,函数其实是对象的一种 函数、构造函数的区别,任何函数都可以作为构造函数,但是并不能将任意函数叫做构造函数&…...
力扣题单(小白友好)
力扣题单 算法小白自用题单,目前对于一些简单的数据结构感觉掌握的还可以,但是力扣很多题还是需要看题解,不够熟练;故整理了一份题单,用于巩固练习; 网上确实有很多对于算法分类讲解的网站,but:有一丢丢选择困难症,每天不知道该刷什么题,再加上网站对于一类题一般就有十几道题目…...
王道c语言ch11-单链表的新建、插入、删除例题
王道c语言ch11-单链表的新建、插入、删除例题 #include <stdio.h> #include <stdlib.h> #define END 33typedef int ElemType;typedef struct LNote {ElemType data;struct LNote *next; } LNote, *LinkList;//头插法 void list_head_insert(LinkList &L) {El…...
蓝桥杯刷题--python-23
2.危险系数 - 蓝桥云课 (lanqiao.cn) n, m map(int, input().split()) map_ [[] for i in range(n 1)] used [0 for i in range(n 1)] used_ [0 for i in range(n 1)] cnt 0 res [] for _ in range(m):u, v map(int, input().split())map_[u].append(v)map_[v].appen…...
蓝桥杯刷题--python-24
0地图 - 蓝桥云课 (lanqiao.cn) from math import * import sys from functools import lru_cache # sys.setrecursionlimit(100000) n, m, k map(int, input().split()) a [input() for i in range(n)] dr [(0, 1), (1, 0)] cnt 0 lru_cache(maxsizeNone) def dfs(x, y, …...
面向对象(C# )
面向对象(C# ) 文章目录 面向对象(C# )ref 和 out传值调用和引用调用ref 和 out 的使用ref 和 out 的区别 结构体垃圾回收GC封装成员属性索引器静态成员静态类静态构造函数拓展方法运算符重载内部类和分布类 继承里氏替换继承中的…...
Lombok:@Cleanup资源释放利器
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 一、Cleanup介绍 二、使用示例 三、价值阐述 总结 提示:以下是本篇文章正文内容,下面案例可供参考 一、Cleanup介绍 Cleanup可以自动管理输…...
IoT 物联网场景中 LoRa + 蓝牙Bluetooth 室内场馆高精定位技术全面解析
基于LoRa蓝牙的室内场景定位技术,蓝牙主要负责位置服务,LoRa主要负责数据传输。 01 LoRa和蓝牙技术 LoRa全称 “Long Rang”,是一种成熟的基于扩频技术的低功耗、超长距离的LPWAN无线通信技术。LoRa主要采用的是窄带扩频技术,抗干…...
3个步骤让你在电脑上畅玩Switch游戏:Ryujinx模拟器完全指南
3个步骤让你在电脑上畅玩Switch游戏:Ryujinx模拟器完全指南 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 你是否曾经想过,如果能在自己的电脑上体验《塞尔达传…...
从VGG16到Xception:手把手拆解DeepLab系列四大版本的核心演进与代码实现
从VGG16到Xception:DeepLab系列四大版本核心技术演进与实战解析 语义分割技术正经历着从基础架构到精细化设计的快速迭代。作为这一领域的标杆性工作,DeepLab系列从2015年的v1版本到2018年的v3版本,展现了一条清晰的技术演进路径——从最初的…...
雪女-斗罗大陆-造相Z-Turbo开发环境搭建:Node.js后端服务配置指南
雪女-斗罗大陆-造相Z-Turbo开发环境搭建:Node.js后端服务配置指南 想自己动手搭建一个能调用“雪女-斗罗大陆-造相Z-Turbo”这类AI模型的后端服务吗?如果你对全栈开发感兴趣,或者想为自己的应用增加AI图像生成能力,这篇文章就是为…...
谷歌Brain++液态神经网络实战:5分钟看懂如何用动态权重提升无人机避障性能
谷歌Brain液态神经网络实战:动态权重如何重塑无人机避障逻辑 当无人机在密集的竹林间穿行时,传统神经网络需要消耗大量算力处理每一帧图像,而液态神经网络(LNNs)的神经元连接权重会像液体一样根据气流变化实时调整——…...
告别KITTI格式焦虑:手把手教你用MMDetection3D处理自定义点云数据集(含PLY/OBJ转换)
告别KITTI格式焦虑:手把手教你用MMDetection3D处理自定义点云数据集(含PLY/OBJ转换) 当研究者首次尝试将自采集的3D点云数据投入MMDetection3D框架时,往往会陷入数据格式适配的困境。不同于标准KITTI数据集提供的.bin文件…...
从无人机飞控到机械臂:工程师如何用四元数(Quaternion)彻底告别‘万向死锁’的烦恼
从无人机飞控到机械臂:工程师如何用四元数彻底告别万向死锁 想象一下,你正在调试一架无人机的飞控系统。当飞机俯仰角接近90度时,突然发现滚转和偏航控制开始互相干扰,原本独立的三个轴向操作突然"锁死"成两个——这就是…...
如何用5分钟彻底告别水印烦恼:全网资源下载终极指南
如何用5分钟彻底告别水印烦恼:全网资源下载终极指南 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader 你是否曾经为…...
《QGIS快速入门与应用基础》288:多波段影像加载(识别红/绿/蓝/近红外波段)
作者:翰墨之道,毕业于国际知名大学空间信息与计算机专业,获硕士学位,现任国内时空智能领域资深专家、CSDN知名技术博主。多年来深耕地理信息与时空智能核心技术研发,精通 QGIS、GrassGIS、OSG、OsgEarth、UE、Cesium、OpenLayers、Leaflet、MapBox 等主流工具与框架,兼具…...
小白也能玩转电影特效:ANIMATEDIFF PRO快速制作慢动作诗意镜头
小白也能玩转电影特效:ANIMATEDIFF PRO快速制作慢动作诗意镜头 1. 为什么选择ANIMATEDIFF PRO制作电影特效? 1.1 传统电影特效制作的门槛 过去想要制作专业级的电影特效,你需要面对三重障碍: 硬件门槛:需要价值数万…...
PaddleOCR C++推理部署实战:轻量级vs服务器级模型效果对比与性能调优指南
PaddleOCR C推理部署实战:轻量级vs服务器级模型效果对比与性能调优指南 OCR技术在实际业务场景中的应用越来越广泛,而模型的选择和性能调优往往是开发者最关心的问题。本文将带你深入探索PaddleOCR在C环境下的推理部署,重点对比轻量级和服务…...
