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语言编程的常用接口,并编写测试用例进行测试。

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

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

相关文章

uni微信小程序editor富文本组件如何插入图片

需求 在editor中插入图片&#xff0c;并对图片进行编辑&#xff0c;简略看一下组件的属性&#xff0c;官网editor 组件 | uni-app官网 解决方案 首先要使用到ready这个属性&#xff0c;然后官网有给代码粘过来&#xff0c;简单解释一下这段代码的意思&#xff08;作用是在不同…

星火秘境游戏开发链游app定制开发源码部署

星火秘境是一款神秘而充满冒险的游戏&#xff0c;开发这样一款游戏需要综合考虑多个方面&#xff0c;包括游戏设计、美术设计、程序开发、音效制作等。下面我将简要介绍一下游戏开发和链游app搭建的一般流程&#xff1a; 游戏设计&#xff1a; 确定游戏类型&#xff1a;星火秘…

webgl_effects_stereo

ThreeJS 官方案例学习&#xff08;webgl_effects_stereo&#xff09; 1.效果图 2.源码 <template><div><div id"container"></div></div> </template> <script> import * as THREE from three; // 导入控制器 import { …

碳课堂|一文梳理国际碳标准发展历程

在全球气候行动的浪潮中&#xff0c;国际碳标准作为衡量和指导组织与产品环境影响的重要工具&#xff0c;其发展历程不仅标志着环境保护意识的觉醒&#xff0c;也反映了全球合作对抗气候变化的决心。从产品碳足迹的评估到组织碳排放的监控&#xff0c;再到碳中和目标的追求&…

天润酸奶爆改饭盒?为什么听劝营销“硬控”消费者如此有效

不知道大家会不会经常逛超市&#xff1f;有没有发现酸奶货架上有一道异于其它品牌的包装&#xff0c;它就是新疆天润酸奶&#xff0c;酷似饭盒的外包装对于当代倡导实用主义的年轻人来讲&#xff0c;这一发现无疑是直接“创进心巴”&#xff0c;不少网友表示它直接解决了带饭人…

HiveQL性能调优-概览

一、铺垫 1、HiveQL 在执行时会转化为各种计算引擎的能够运行的算子&#xff0c;这里以mr引擎为切入点&#xff0c;要想让HiveQL 的效率更高&#xff0c;就要理解HiveQL 是如何转化为MapReduce任务的 2、hive是基于hadoop的&#xff0c;分布式引擎采用mr、spark、tze&#x…

前端面试题(二)答案版

面试形式&#xff1a;线上面试&#xff08;不露脸&#xff09;&#xff1a;时长40分钟 面试评价&#xff1a;由易到难&#xff0c;由细到全&#xff0c;比较不错 面试官&#xff1a;项目经理 面试官提问&#xff08;面试题&#xff09;&#xff1a; 1、聊聊最近写的这个项目…

WordPress--批量关闭 Pingback 和 Trackback

原文网址&#xff1a;WordPress--批量关闭 Pingback 和 Trackback_IT利刃出鞘的博客-CSDN博客 简介 本文介绍WordPress如何批量关闭 Pingback 和 Trackback。 新发布文章默认关闭 在设置> 讨论中关闭如下两项&#xff1a; 关闭已经发布的文章 UPDATE wp_posts SET ping…

三石峰汽车生产厂的设备振动检测项目案例

汽车生产厂的设备振动检测项目 ----天津三石峰科技&#xff08;http://www.sange-cbm.com&#xff09; 汽车产线有很多传动设备需要长期在线运行&#xff0c;会出现老化、疲劳、磨损等问题&#xff0c;为了避免意外停机造成损失&#xff0c;需要加装一些健康监测设备&#xf…

第34届健博会亮点揭秘:行心科技与段氏常春堂携手共创医康养新生态

随着《“健康中国2030”规划纲要》的持续推进&#xff0c;健康服务业已成为推动经济社会持续发展的重要力量。在即将到来的2024年&#xff0c;第34届健博会暨中国大健康产业文化节&#xff08;以下简称“大健康博览会”&#xff09;将在广州保利世贸博览馆盛大开幕。本届展会汇…

武汉科技大学,计算机考研全面改考408,24计算机专硕复试线仅298分!武汉科技大学计算机考研考情分析!

武汉科技大学&#xff08;Wuhan University of Science and Technology&#xff09;简称“武科大”&#xff0c;坐落于湖北省武汉市&#xff0c;是湖北省人民政府、教育部和六家国家特大型企业共建高校&#xff0c;是湖北省“双一流”建设重点高校&#xff0c;入选国家“中西部…

我的名字叫大数据: 第7章 我的自拍展

7.1 生活瞬间:通过数据图像呈现 数据健身达人们!在经过一系列的辛勤锻炼后,是时候来看看我的“自拍展”了。通过数据图像,我们不仅可以更直观地了解数据,还能将复杂的信息以简单而美观的方式呈现出来。在这一节中,我将带你领略各种数据图像的魅力,从色彩缤纷的条形图到…

亮数据代理IP助力高效数据采集

文章目录 &#x1f4d1;前言一、爬虫数据采集痛点二、代理IP解决爬虫痛点2.1 为什么可以2.2 本篇采用的代理IP 四、零代码获取数据4.1 前置背景4.2 亮数据浏览器自动抓取数据4.3 使用步骤&#xff1a; 五、数据集5.1 免费样本5.2 定制数据集 &#x1f324;️个人小结 &#x1f…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-24.5,6 SPI驱动实验-ICM20608 ADC采样值

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

如何扫描照片?分享推荐这三款软件!

在数字化时代&#xff0c;将纸质照片转化为电子版已成为一种常见需求。无论是为了保存珍贵的回忆&#xff0c;还是为了方便分享和编辑&#xff0c;照片扫描软件都发挥着不可替代的作用。今天&#xff0c;我将为大家推荐三款优秀的照片扫描软件&#xff0c;帮助大家轻松完成照片…

GB28181安防视频融合汇聚平台EasyCVR如何实现视频画面自定义标签?

安防视频融合汇聚平台EasyCVR兼容性强&#xff0c;可支持Windows系统、Linux系统以及国产化操作系统等&#xff0c;平台既具备传统安防视频监控的能力&#xff0c;也具备接入AI智能分析的能力&#xff0c;可拓展性强、视频能力灵活&#xff0c;能对外分发RTMP、RTSP、HTTP-FLV、…

Camtasia Studio2024永久免费版及最新版本功能讲解

在当前数字化时代&#xff0c;视频内容的制作与编辑变得愈发重要。无论是企业宣传、在线教育还是个人Vlog制作&#xff0c;一款功能强大且易于上手的视频编辑软件成为了刚需。Camtasia Studio作为市场上备受欢迎的视频编辑与屏幕录像工具&#xff0c;凭借其强大的功能与用户友好…

芒果YOLOv8改进169:即插即用 | 秩引导的块设计核心CIB结构,设计一种秩引导的块设计方案,旨在通过紧凑型架构设计减少被显示为冗余的阶段的复杂性

💡🚀🚀🚀本博客 秩引导的块设计,设计了一种秩引导的块设计方案,旨在通过紧凑型架构设计减少被显示为冗余的阶段的复杂性 :内含源代码改进 适用于 YOLOv8 按步骤操作运行改进后的代码即可 文章目录 即插即用|秩引导的块设计|最新改进 YOLOv8 代码改进论文理论YOLO…

GA/T 1400视频汇聚平台EasyCVR级联后,平台显示无通道是什么原因?

国标GB28181安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台部署轻快&#xff0c;可支持的主流标准协议有GA/T 1400、国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。 有用户反馈&#xff…

289M→259M得物包体积治理实践

一、前言 iOS应用的包体积大小是衡量得物性能的重要指标&#xff0c;过大包体积会降低用户对应用的下载意愿&#xff0c;还会增加用户的下载等待时间以及用户手机的存储空间&#xff0c;本文重点介绍在包体积治理中的新思路以及原理与实践。 二、原理介绍 Macho产物测试 我…