SQLiteC/C++接口详细介绍sqlite3_stmt类(一)

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

上一篇:SQLiteC/C++接口详细介绍sqlite3_stmt类简介

下一篇:SQLiteC/C++接口详细介绍sqlite3_stmt类(二) 

序言:

本文开始了SQLite的第二个类的详细介绍了,有兴趣的朋友可以关注更新一下。 

1、sqlite3_prepare_v2()

`sqlite3_prepare_v2`是SQLite库中的一个函数,用于将一个SQL语句编译成字节码,以便于执行SQL语句和检查语法错误。该函数的详细形式如下:

```c
int sqlite3_prepare_v2(
  sqlite3 *db,            /* Database handle */
  const char *zSql,       /* SQL statement, UTF-8 encoded */
  int nByte,              /* Length of zSql in bytes */
  sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
  const char **pzTail     /* OUT: Pointer to unused portion of zSql */
);
```

其中,`sqlite3 *db`是一个数据库句柄,代表与SQLite数据库的连接。`const char *zSql`是一个指向包含SQL语句的字符串的指针,`int nByte`是该字符串的字节数。`sqlite3_stmt **ppStmt`是一个输出参数,指向一个`sqlite3_stmt`类型的指针,该指针指向SQL语句编译后的二进制字节码。`const char **pzTail`也是一个输出参数,指向指向未使用的SQL语句的指针。

函数返回一个整数,表示执行成功或者出现错误。如果执行成功,返回SQLITE_OK,如果出现错误,返回对应的错误代码。

下面是一个使用`sqlite3_prepare_v2`的示例代码:```c

sqlite3 *db;
sqlite3_stmt *stmt;
const char *tail;
char *sql = "SELECT * FROM users WHERE age > ?;";
int rc = sqlite3_open("test.db", &db);
if(rc != SQLITE_OK){// handle error
}
rc = sqlite3_prepare_v2(db, sql, -1, &stmt, &tail);
if(rc != SQLITE_OK){// handle error
}
int age = 18;
sqlite3_bind_int(stmt, 1, age); // Bind the parameter to the prepared statement.
while(sqlite3_step(stmt) == SQLITE_ROW) {// Process each row of results.// In this example, we're simply printing each row to the console.printf("id: %d, name: %s, age: %d\n", sqlite3_column_int(stmt, 0),sqlite3_column_text(stmt, 1), sqlite3_column_int(stmt, 2));
}
sqlite3_finalize(stmt);
sqlite3_close(db);

在这个示例中,我们首先打开了一个名为`test.db`的SQLite数据库。然后,我们创建了一个包含`?`占位符的SQL语句,用于查询年龄大于指定年龄的用户。接着,我们调用了`sqlite3_prepare_v2`函数来编译这个SQL语句,并将编译后的语句存储在`stmt`中。我们还调用了`sqlite3_bind_int`函数来绑定一个整型参数到我们编译的SQL语句中。然后我们通过循环的方式执行了我们的SQL语句,并将查询结果输出到控制台。最后,我们调用了`sqlite3_finalize`函数来释放编译后的SQL语句,并调用`sqlite3_close`函数关闭我们的数据库连接。

使用`sqlite3_prepare_v2`函数编译SQL语句非常有用,因为它允许我们重复使用相同的SQL语句,同时确保正确处理用户输入,以防SQL注入等安全问题。

2、sqlite3_bind_*()

`sqlite3_bind_*()`是SQLite库中的一组函数,用于向SQL语句中的参数绑定值。通过绑定参数,我们可以避免SQL注入等常见的安全问题,并且可以大大提高程序性能。

这组函数的语法如下:

int sqlite3_bind_int(sqlite3_stmt*, int, int);
int sqlite3_bind_int64(sqlite3_stmt*, int, sqlite3_int64);
int sqlite3_bind_double(sqlite3_stmt*, int, double);
int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int, void(*)(void*));
int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int, void(*)(void*));
int sqlite3_bind_null(sqlite3_stmt*, int);

其中,第一个参数是一个已经编译好的SQL语句对象,第二个参数是一个参数的位置,第三个参数是参数的值。根据不同的参数类型,例如整数、浮点数、文本和二进制数据,我们可以从上面的函数中选择不同的函数来完成参数绑定。

这里有一个例子,展示了如何在SQL语句中使用参数,并使用`sqlite3_bind_*()`函数设置参数:

sqlite3_stmt *stmt;
int rc = sqlite3_prepare_v2(db, "SELECT * FROM users WHERE id = ? AND name = ?;", -1, &stmt, NULL);
if (rc != SQLITE_OK) {// handle error condition
}
// Bind data to the parameters of the prepared statement.
sqlite3_bind_int(stmt, 1, 100);
sqlite3_bind_text(stmt, 2, "John Doe", -1, NULL);
// Iterating over the result set would go here.

在这个示例中,我们编译了一个SQL语句,其中包含两个参数`id`和`name`,我们在编译时通过`?`占位符标记这两个参数。然后,我们使用`sqlite3_bind_ *()`函数设置参数的值,注意这两个函数需要接收SQL语句中变量的位置和实际变量的值。在这个例子中,我们将整数100绑定到`id`参数,把文本字符串 "John Doe" 绑定到 `name` 参数。最后,我们可以通过迭代查询结果集来处理检索到的数据。总之,使用`sqlite3_bind_*()`来设置参数绑定值,避免了SQL注入安全问题和可读性问题,并且提高了SQL语句的可重用性和性能。该函数可用于所有支持参数化SQL查询的SQLite版本中,并且是编写与SQLite进行交互的C/C++应用程序的必要技能之一。

3、sqlite3_step()

`sqlite3_step()`是SQLite库中的一个函数,用于执行已经编译好的SQL语句。该函数的语法如下:

int sqlite3_step(sqlite3_stmt*);

其中,`sqlite3_stmt*`是一个指向已编译的SQL语句的指针。函数的返回值有以下几种情况:

- `SQLITE_ROW`: 该值表示查询产生了一行结果。
- `SQLITE_DONE`: 该值表示SQL语句已经执行完成,没有更多的行数。
- `SQLITE_ERROR`: 该值表示运行出错,例如SQL语法错误、不存在的表或列名等。
- `SQLITE_BUSY`: 需要等待Oracle锁来访问一个SQLite3对象,但此时它正在被其他线程使用。
- `SQLITE_MISUSE`: 表示API被错误地使用。
- `SQLITE_CONSTRAINT`: 表示已存在一个重复项,即数据表中已经存在当前需要插入的数据。
- `SQLITE_NOMEM`: 表示内存不足,无法分配内存。下面是一个使用`sqlite3_step()`的例子,用于查询所有用户的姓名和年龄:

sqlite3 *db;
sqlite3_stmt *stmt;
char sql[] = "SELECT name, age FROM users;";
int rc = sqlite3_open_v2("test.db", &db, SQLITE_OPEN_CREATE | SQLITE_OPEN_READWRITE, NULL);
if (rc != SQLITE_OK) {sqlite3_close(db);return 1;
}
rc = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (rc == SQLITE_OK) {while (sqlite3_step(stmt) == SQLITE_ROW) {const char *name = (const char*) sqlite3_column_text(stmt, 0);int age = sqlite3_column_int(stmt, 1);printf("name: %s, age: %d\n", name, age);}
} else {// handle error
}
sqlite3_finalize(stmt);
sqlite3_close(db);

在这个例子中,我们首先使用`sqlite3_open_v2`函数打开了一个SQLite数据库,并用`sqlite3_prepare_v2`函数编译了一个SQL语句。然后,我们可以使用`sqlite3_step()`函数查询数据库中的所有用户信息。在这个例子中,我们使用了一个while循环遍历每一个查询到的结果行,从结果行中提取每个字段的值并打印输出。总之,`sqlite3_step()`函数用于执行已经编译好的SQL语句,并从查询结果中获取数据。使用该函数,可以编写出高效、健壮的SQLite应用程序。

由于这2天出差导致昨天不能更新,今天也编写比较匆忙,有不足之处还请见谅!

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

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

相关文章

Qt 容器类控件

Group Box 使用 QGroupBox 实现一个带有标题的分组框可以把其他的控件放到里面作为一组,这样看起来能更好看一点. 核心属性 属性说明title分组框的标题alignment分组框内部内容的对齐方式flat是否是 “扁平” 模式checkable是否可选择. 设为 true,则在…

鸿蒙Harmony应用开发—ArkTS-高级组件:@ohos.advertising.AdComponent (非全屏广告展示组件))

本模块提供展示非全屏广告的能力。 说明: 本模块首批接口从API Version 11开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 导入模块 import { AdComponent } from ohos.advertising.AdComponent; AdComponent AdComponent(ads: Ar…

webpack5零基础入门-12搭建开发服务器

1.目的 每次写完代码都需要手动输入指令才能编译代码,太麻烦了,我们希望一切自动化 2.安装相关包 npm install --save-dev webpack-dev-server 3.添加配置 在webpack.config.js中添加devServer相关配置 /**开发服务器 */devServer: {host: localhos…

华为中心AP 配置入侵防御实验

配置入侵防御示例 组网图形 图1 入侵防御组网图 组网需求配置思路操作步骤中心AP的配置文件 组网需求 如图1所示,某企业部署了WLAN网络,内网用户可以访问Internet的Web服务器。现需要在中心AP上配置入侵防御功能,具体要求如下: 保…

Bert的一些理解

Bert的一些理解 Masked Language Model (MLM)Next Sentence Prediction (NSP)总结 参考链接1 参考链接2 BERT 模型的训练数据集通常是以预训练任务的形式来构建的,其中包括两个主要任务:Masked Language Model (MLM) 和 Next Sentence Prediction (NSP)。…

GPT-4与Claude3、Gemini、Sora:AI领域的技术创新与突破

【最新增加Claude3、Gemini、Sora、GPTs讲解及AI领域中的集中大模型的最新技术】 2023年随着OpenAI开发者大会的召开,最重磅更新当属GPTs,多模态API,未来自定义专属的GPT。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义,不亚…

【PG数据库】CentOS 7 安装 PostgreSQL 14

1 CentOS 7 安装 PostgreSQL 14 1.1下载离线安装包 下载方式:利用离线下载方式在虚拟机中安装PostgreSQL 14 下载链接: https://yum.postgresql.org/14/redhat/rhel-7-x86_64/repoview/postgresqldbserver14.group.html 依次进入下载: 1.…

深度访谈:OpenAI缘何要进军光量子领域

内容来源:量子前哨(ID:Qforepost) 编辑丨王珩 编译/排版丨沛贤 深度好文:2000字丨12分钟阅读 据报道,人工智能巨头最近为其团队增添了一位新成员:Ben Bartlett,他是PsiQuantum的前…

【QT+QGIS跨平台编译】之八十四:【QGIS_Gui跨平台编译】—【错误处理:未实例化QgsMapLayer - QgsHighlight】

文章目录 一、未实例化QgsMapLayer二、错误处理 一、未实例化QgsMapLayer 报错信息: 二、错误处理 第31行修改为: #include "qgsmaplayer.h"

HarmonyOS NEXT应用开发之多文件下载监听案例

介绍 多文件下载监听在应用开发中是一个非常常见的需求。本示例将介绍如何使用request上传下载模块实现多文件下载监听,如监听每个文件下载任务的进度,任务暂停,下载完成等下载情况。每个应用最多支持创建10个未完成的任务,相关规…

GB28181视频汇聚EasyCVR平台接入海康Ehome设备,设备在线但是视频无法播放是什么原因?

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

云原生相关知识

一、kubernetes 1 概述 Kubernetes(也称 k8s 或 “kube”)是一 个​​开源​​的容器编排平台,可以自动完成在部署、管理和扩展容器化应用过程中涉及的许多手动操作。 我们常说的编排的英文单词为 “Orchestration”,它常被解释…

苹果意将Gemini引入iPhone;英伟达发布新AI GPU;Grok正式开源

苹果正在谈判将 Gemini 引入 iPhone Mark Gurman 报道,苹果正在谈判将 Google 的生成式 AI 大模型 Gemini 引入 iPhone。 知情人士透露,两家公司正在积极谈判,让苹果获得 Gemini 授权,为今年 iPhone 软件的一些新功能提供动力。苹…

vim | vim多标签之间的跳转

比如有两个标签: 按 Ctrl o 会直接跳转到上一次打开的文件,这样可能不够直观,可以用 :ls 进行查看buff,如下: 可以看到 %a 的是当前正在编辑的 # 是按 Ctrl o 会跳转到的 当然也可以用 这种命令进行跳转&#xff1…

基于SpringBoot+Redis实现接口限流

前言 业务中需要对一些接口进行限流处理&#xff0c;防止机器人调用或者保证服务质量&#xff1b; 实现方式 基于redis的lua脚本 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis&…

stm32之GPIO电路介绍

文章目录 1 GPIO介绍2 GPIO的工作模式2.1 浮空输入2.2 上拉输入2.3 下拉输入2.4 模拟输入2.5 开漏输出2.6 推挽输出2.7 复用开漏输出2.8 复用推挽输出2.9 其他 3 应用方式4 常用库函数 1 GPIO介绍 保护二极管&#xff1a;保护引脚&#xff0c;让引脚的电压位于正常的范围施密特…

【Linux(1)】Linux的一些基本指令(补充上一篇)

思维导图 学习内容 通过上面的学习目标&#xff0c;我们可以列出要学习的内容&#xff1a; linux的一些指令&#xff1a;cd mkdir cp touch which rm cat alias 一些基本的概念&#xff1a;指令的概念&#xff0c;用户家目录是什么...... 一、Linux的一些指令 1.1 重新认识…

【机器学习】无监督学习算法之:自编码器

自编码器 1、引言2、自编码器2.1 定义2.2 原理2.3 实现方式2.4 算法公式2.5 代码示例 3、总结 1、引言 小屌丝&#xff1a;鱼哥&#xff0c; 今天可以讲一讲 自编码器嘛 小鱼&#xff1a;请说清楚&#xff0c;是什么编码器&#xff1f; 小屌丝&#xff1a;自编码器 小鱼&#…

除了大众点评,中国未来还会产生多少家这样的人工智能公司? - 学习Yelp公司的软件工程-评价和推荐系统

原文作者&#xff1a;Jason Sleight&#xff0c;ML&#xff08;Machine Learning&#xff09;平台集团技术负责人 翻译&#xff1a;数字化营销工兵 了解数据是Yelp成功的重要组成部分。为了将我们的消费者与当地优秀的企业联系起来&#xff0c;我们每天为各种任务提供数百万条建…

前端面试02(JS)

文章目录 前端面试02&#xff08;JS&#xff09;1、js的组成2、js内置对象3、操作数组的方法4、数据类型的检测方法5、闭包是什么6、前端内存泄漏7、事件委托8、基本数据类型和引用数据类型9、原型链10、JS如何实现继承 &#x1f389;写在最后 前端面试02&#xff08;JS&#x…