Linux应用 sqlite3编程

1、概念

SQLite3是一个轻量级的、自包含的、基于文件的数据库管理系统,常用于移动设备、嵌入式设备和小型应用程序中,应用场景如下:

  • 移动应用程序:由于SQLite3是零配置、无服务器的数据库引擎,非常适合用于移动应用程序中,如本地数据存储、离线访问等功能。

  • 嵌入式设备:SQLite3的小型性和零配置特性使得它成为许多嵌入式设备中的理想选择,包括智能家居设备、物联网设备等。

  • 小型应用程序:对于小型的桌面应用程序、小型网站等,SQLite3是一个不错的选择,因为它易于使用和部署。

2、常用命令

Ubuntu下使用apt-get install sqlite3安装。

2.1 创建数据库文件

直接使用sqlite3命令会将数据库创建在内存中,使用sqlite3 + 数据库名称可以将数据库文件创建到当前目录下,如果数据库文件已经存在则会打开:

2.2 创建表格

使用CREATE TABLE进行表格创建,对于以下示例:

CREATE TABLE users (id INTEGER PRIMARY KEY,name TEXT,age INTEGER);
  • CREATE TABLE users :这部分语句表示要创建一个名为users的表。
  • id INTEGER PRIMARY KEY,:这部分定义了第一个列(或字段)id,数据类型为INTEGER,并且将其定义为主键(PRIMARY KEY)。主键是用来唯一标识每一行记录的字段,可以保证表中每一行的唯一性。
  • name TEXT,:这部分定义了第二个列name,数据类型为TEXT,用来存储文本字符串类型的数据。 age INTEGER: 这部分定义了第三个列age,数据类型为INTEGER,用来存储整数类型的数据。

在此SQL语句中,id列被定义为主键,所以它的值必须是唯一的,并且不能为空。其他列name和age可以包含空值(NULL)。

2.3 查看表格

.tables命令可以查看表格,.schema可以查看表结构:

2.4 插入数据

使用INSERT INFO进行数据插入:

INSERT INTO users (name, age) VALUES ('张三', 25);
INSERT INTO users (name, age) VALUES ('李四', 30);

2.5 数据查询

使用SELECT 进行数据查询:

2.6 数据更新

使用UPDATE 进行数据更新:

2.7 数据删除

使用DELETE 进行数据删除:

2.8 退出

使用.exit命令退出。

3、C语言编程常用接口

执行apt-get install libsqlite3-dev安装开发文件,libsqlite3-dev是SQLite数据库的C语言接口的开发文件。它包含了用于在C/C++程序中访问SQLite数据库的头文件和静态库文件。

开发接口在官网中有介绍:An Introduction To The SQLite C/C++ Interface

3.1 sqlite3_open

打开一个SQLite数据库文件。

  • 原型:int sqlite3_open(const char *filename, sqlite3 **ppDb)
  • 入参:filename 为数据库文件名,ppDb 是指向 sqlite3* 结构体指针的指针
  • 返回值:返回 SQLITE_OK 表示成功,其它错误码表示失败
3.2 sqlite3_exec

执行一条SQL语句

  • 原型:int sqlite3_exec(sqlite3* db, const char* sql, int (*callback)(void*,int,char**,char**), void* data, char** errmsg)
  • 入参:db 为数据库指针,sql 为要执行的SQL语句,callback 为结果处理回调函数,data 为回调函数接受的参数
  • 返回值:返回 SQLITE_OK 表示成功,其它错误码表示失败

回调函数的原型为 int (*callback)(void*, int, char**, char**)。具体来说:

  • void* 参数是通过 sqlite3_exec 的第四个参数传递给回调函数的自定义数据。
  • int 参数 argc 是结果集中返回的列数。
  • char** 参数 argv 是一个包含每一列的值的数组。
  • char** 参数 azColName 是一个包含每一列的列名的数组。
  • 回调函数应该返回一个整数值,非零值表示需要终止查询,0 表示继续执行。
3.3 sqlite3_prepare_v2

编译 SQL 语句并准备好一个语句对象,以便稍后执行和绑定参数。

  • 原型:int sqlite3_prepare_v2(sqlite3* db, const char* zSql, int nByte, sqlite3_stmt** ppStmt, const char** pzTail);

    • db:SQLite 数据库对象。
    • zSql:要编译的 SQL 语句。
    • nByte:SQL 语句的长度(-1 表示自动计算长度)。
    • ppStmt:返回的准备好的语句对象。
    • pzTail:指向剩余未使用的部分(可选)。
  • 返回值:如果 SQL 语句编译成功,则返回 SQLITE_OK,并将准备好的语句对象放入 ppStmt 中;如果出现错误,则返回对应的错误码。

3.4 sqlite3_step

用于执行准备好的语句对象,一次执行一步。

  • 原型:int sqlite3_step(sqlite3_stmt* pStmt);
  • 入参:准备好的语句对象。
  • 返回值:如果执行成功,返回 SQLITE_ROW 或 SQLITE_DONE;如果出现错误,返回其他错误码。
3.5 sqlite3_bind_int

将整数值绑定到 SQL 语句中的参数位置。

  • 原型:int sqlite3_bind_int(sqlite3_stmt* pStmt, int idx, int val);

    • pStmt:准备好的语句对象。
    • idx:参数的索引(1-based)。
    • val:要绑定的整数值。
  • 返回值:执行成功时返回 SQLITE_OK,否则返回对应的错误码。

3.6 sqlite3_finalize

用于释放准备好的语句对象。

  • 原型:int sqlite3_finalize(sqlite3_stmt* pStmt);
  • 入参:要释放的准备好的语句对象。
  • 返回值:成功时返回 SQLITE_OK,失败时返回其他错误码
3.7 sqlite3_close

关闭一个打开的SQLite数据库

  • 原型:int sqlite3_close(sqlite3*)
  • 入参:数据库指针
  • 返回值:返回 SQLITE_OK 表示成功,其它错误码表示失败
3.8 说明
  • sqlite3_finalize:释放由 sqlite3_prepare 或 sqlite3_prepare_v2 分配的准备语句对象。
  • sqlite3_free_table:释放通过 sqlite3_get_table 函数获得的结果表。
  • sqlite3_free_stmt:释放通过 sqlite3_prepare_v2 函数获得的语句对象。

理论上,可以说 sqlite3_exec 可以实现 sqlite3_prepare_v2 的功能,但是它们的设计和用途有所不同。

  • sqlite3_exec 主要用于执行一次性、不需要绑定参数的 SQL 语句操作,并且适合用于执行不返回结果集的 SQL 操作,比如创建表、插入数据、更新数据等。其优点在于简单直接,适用于简单的 SQL 操作。

  • sqlite3_prepare_v2 主要用于执行需要绑定参数、需要多次执行、或者需要获取结果集的 SQL 操作。通过预编译 SQL 语句,可以提高执行效率,并且可以使用参数绑定来防止 SQL 注入攻击。虽然在一些情况下可以通过拼接 SQL 语句并结合 sqlite3_exec 来模拟其功能,但不如 sqlite3_prepare_v2 灵活和安全。

4、编程示例

编写如下测试代码:

#include <sqlite3.h>
#include <stdio.h>

// 回调函数,用于在 sqlite3_exec 中处理查询结果
static int callback(void* NotUsed, int argc, char** argv, char** azColName) 
{
    for (int i = 0; i < argc; i++) 
    {
        printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
    }
    printf("\n");
    return 0;
}

int main() 
{
    sqlite3* db;
    char* errMsg = 0;

    // 打开数据库连接
    int rc = sqlite3_open("usr.db", &db);
    if (rc) 
    {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        return rc;
    }

    // 创建表
    const char* createTableSQL = "CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER);";
    rc = sqlite3_exec(db, createTableSQL, NULL, 0, &errMsg);
    if (rc != SQLITE_OK) 
    {
        fprintf(stderr, "SQL error: %s\n", errMsg);
        sqlite3_free(errMsg);
        sqlite3_close(db);
        return rc;
    }

    // 插入数据
    const char* insertDataSQL = "INSERT OR IGNORE INTO users (name, age) VALUES ('zhao', 30), ('qian', 25), ('sun', 35);";
    rc = sqlite3_exec(db, insertDataSQL, NULL, 0, &errMsg);
    if (rc != SQLITE_OK) 
    {
        fprintf(stderr, "SQL error: %s\n", errMsg);
        sqlite3_free(errMsg);
        sqlite3_close(db);
        return rc;
    }

    // 使用 sqlite3_exec 查询所有数据
    const char* selectDataSQL = "SELECT * FROM users;";
    rc = sqlite3_exec(db, selectDataSQL, callback, 0, &errMsg);
    if (rc != SQLITE_OK) 
    {
        fprintf(stderr, "SQL error: %s\n", errMsg);
        sqlite3_free(errMsg);
        sqlite3_close(db);
        return rc;
    }

    // 使用 sqlite3_prepare_v2 查询数据
    sqlite3_stmt* stmt;
    const char* selectDataSQL2 = "SELECT * FROM users WHERE age > ?;";
    rc = sqlite3_prepare_v2(db, selectDataSQL2, -1, &stmt, NULL);
    if (rc != SQLITE_OK) 
    {
        fprintf(stderr, "SQL error: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return rc;
    }

    // 检索年龄大于25的行
    int minAge = 25;
    sqlite3_bind_int(stmt, 1, minAge);

    while (sqlite3_step(stmt) == SQLITE_ROW)
    {
        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);

    return 0;
}

测试结果如下:

5、总结

本文讲解了sqlite3的常用命令和c语言编程的常用接口,并编写测试用例进行测试。

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

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

相关文章

@vue-office/excel 解决移动端预览excel文件触发软键盘

先直接上代码 不耽误大家时间 标明下插件库 非常感谢作者提供预览插件 vue-office/excel 只需要控制CSS :deep(.x-spreadsheet-overlayer) {.x-spreadsheet-selectors {display: none !important;} } :deep(.x-spreadsheet-bottombar) {li.active {user-select: none !import…

PCIe Capability and Extended Capability

PCIe&#xff08;Peripheral Component Interconnect Express&#xff09;是一种用于连接扩展卡到计算机主板的高速串行总线标准。PCIe Capability 和 Extended Capability 是 PCIe 设备的两种重要特性。 1. **PCIe Capability&#xff1a;** PCIe Capability 是指 PCIe 设备的…

HR人才测评,如何做管理岗位的领导力测评?

管理岗位的领导力测评是企业HR人才测评中的重要内容之一&#xff0c;其目的是为了评估管理人员的领导能力和潜力&#xff0c;以便企业在选拔、培养和晋升管理人员时更加科学和有效。 1.明确测评目标和指标 领导力包含多个方面&#xff0c;如领导风格、组织管理、团队建设、决…

2024上海国际钢丝绳及吊索具展览会

2024上海国际钢丝绳及吊索具展览会 2024 Shanghai International Wire Rope and Hanger Exhibition 时间&#xff1a;2024年12月18日--20日 地点&#xff1a;上海新国际博览中心 详询主办方陆先生 I38&#xff08;前三位&#xff09; I82I&#xff08;中间四位&#xff…

Activiti7 Maven笔记

通过maven完成BPMN的创建,定义流程,部署流程,完成流程等操作 代码整合创建maven项目添加log4j日志配置添加activiti配置文件创建数据库 activitijava类编写程序生成表如果代码运行,没有生成表,可能是没有读取到activiti的配置文件 Activiti数据表介绍类关系图工作流引擎创建默认…

城市之旅:使用 LLM 和 Elasticsearch 简化地理空间搜索(一)

作者&#xff1a;来自 Elastic Philipp Kahr, Valentin Crettaz 这篇博文的本地部署实践 Jupyter notebook 请详细阅读文章 “城市之旅&#xff1a;使用 LLM 和 Elasticsearch 简化地理空间搜索&#xff08;二&#xff09;”。 探索如何从自然语言提问创建地理空间搜索。在下…

微信公众号【原子与分子模拟】: 熔化温度 + 超导电性 + 电子化合物 + 分子动力学模拟 + 第一性原理计算 + 数据处理程序

往期内容主要涵盖&#xff1a; 熔化温度 超导电性 电子化合物 分子动力学模拟 第一性原理计算 数据处理程序 【1】熔化温度 分子动力学 LAMMPS 相关内容 【文献分享】分子动力学模拟 LAMMPS 熔化温度 晶体缺陷 熔化方法 LAMMPS 文献&#xff1a;金属熔化行为的局域…

[数据集][目标检测]水下管道泄漏破损检测数据集VOC+YOLO格式2069张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2069 标注数量(xml文件个数)&#xff1a;2069 标注数量(txt文件个数)&#xff1a;2069 标注…

SpringCloud Consul基础入门与使用实践总结

【1】Consul简介 官网地址&#xff1a;https://www.consul.io/intro/index.html 下载地址&#xff1a;https://www.consul.io/downloads.html 中文文档&#xff1a;https://www.springcloud.cc/spring-cloud-consul.html ① 基础概念 Consul 是一套开源的分布式服务发现和…

2024年文艺文化与社会发展国际会议(ICLCSD 2024)

2024年文艺文化与社会发展国际会议 2024 International Conference on Literature, Culture and Social Development 【1】会议简介 2024年文艺文化与社会发展国际会议是一场汇集全球文艺文化和社会科学领域精英的盛会。本次会议以“文艺文化与社会发展”为主题&#xff0c;旨在…

最适合上班族和宝妈的兼职副业,一天500多,小众副业项目

近年来&#xff0c;地方特色小吃逐渐受到人们的热烈追捧&#xff0c;尤其是在直播的助力下&#xff0c;许多地方的特色小吃得以走进大众视野&#xff0c;吸引了大量流量和人气。因此&#xff0c;有很大一部分商家和创业者看准了这一商机&#xff0c;纷纷投身于地方特色小吃的制…

nginx和proxy_protocol协议

目录 1. 引言2. HTTP server的配置3. Stream server的配置3.1 作为proxy_protocol的前端服务器3.2 作为proxy_protocol的后端服务器1. 引言 proxy_protocol 是haproxy开发的一种用于在代理服务器和后端服务器之间传递客户端连接信息的协议。使用 proxy_protocol 的主要优势是能…

系统架构设计师【第15章】: 面向服务架构设计理论与实践 (核心总结)

文章目录 15.1 SOA的相关概念15.1.1 SOA的定义15.1.2 业务流程与BPEL 15.2 SOA的发展历史15.2.1 SOA的发展历史15.2.2 国内SOA的发展现状与国外对比15.2.3 SOA的微服务化发展 15.3 SOA的参考架构15.4 SOA主要协议和规范15.4.1 UDDI协议15.4.2 WSDL规范15.4.3 SOAP协…

子域名太多如何实现HTTPS?一张通配符SSL证书全搞定

在当今数字化时代&#xff0c;网站安全性已经成为网站运营者以及访问者都非常关注的重要问题。部署SSL证书实现HTTPS加密&#xff0c;确保数据传输安全&#xff0c;防止信息被泄露或篡改&#xff0c;消除浏览器“不安全”提示&#xff0c;提高网站安全性以及可信任度已成为必然…

代理IP如何提高网站的SEO排名

目录 一、代理IP的作用 二、使用代理IP提高SEO排名的几种常见方法 1. 采集数据 2. 提交网站 3. 模拟用户行为 4. 搜索引擎优化 三、合理使用代理IP的注意事项 四、代码示例 总结 代理IP是一种可以隐藏真实IP地址的技术&#xff0c;通过使用代理IP&#xff0c;可以实现…

记一次mysql索引优化

生产日志告警出现一条慢 sql 告警, 通过 sql 监控平台拿到 这条sql 语句是 : SELECTid,report_id,report_detail_id,item_code,report_type,photo FROM**** 表 WHEREdel_flag 0 AND (report_type 1 AND report_detail_id IN ( 1742 )) 之后用 explain 分析这条 sql 的命中…

前端框架前置知识之Node.js:Node.js入门

前端程序员有必要学 Node.js 吗&#xff1f;要学到什么程度&#xff1f; 小朋友&#xff0c;你是否有很多问号&#xff1f; 对于node.js&#xff0c;不知道你是否和我一样有很多问号&#xff1f; 其实在学习node.js之前&#xff0c;我已经学完了Vue框架&#xff0c;而且已经…

cad怎么一键闭合所有线

在CAD软件中&#xff0c;将断开的图形快速闭合为一个整体是一项常见且实用的操作。下面详细介绍几种不同的方法来实现一键闭合所有线&#xff1a; 使用圆角命令FILLET 输入命令&#xff1a;在CAD命令行中输入“FILLET”&#xff08;快捷键&#xff1a;F&#xff09;。多选模式&…

122. 买卖股票的最佳时机 II(中等)

122. 买卖股票的最佳时机 II 1. 题目描述2.详细题解3.代码实现3.1 Python3.2 Java 1. 题目描述 题目中转&#xff1a;122. 买卖股票的最佳时机 II 2.详细题解 实现最大的利润&#xff0c;即只要有盈利就收入囊中&#xff0c;由于交易没有具体限制次数&#xff0c;因此可以依…

若依开发-数据库修改密码

若依忘记密码 在SecurityUtils类添加 public static void main(String[] args) {System.out.println(SecurityUtils.encryptPassword("admin123"));}即可打印出加密后密码