主页 > 互联网 > 内容页

环球热推荐:Qt(C++)使用SQLite数据库完成数据增删改查

2023-06-21 09:09:50 来源:DS小龙哥-嵌入式技术
一、项目介绍

当前文章介绍的设计的主要功能是利用 SQLite 数据库实现宠物投喂器上传数据的存储,并且支持数据的增删改查操作。其中,宠物投喂器上传的数据包括投喂间隔时间、水温、剩余重量等参数。

实现功能:

创建 SQLite 数据库表,用于存储宠物投喂器上传的数据。实现对数据库表中数据的插入操作,即将从宠物投喂器接收到的数据存储到数据库中。实现对数据库表中数据的查询操作,包括按照投喂间隔时间、水温、剩余重量等参数进行筛选,以便用户能够查看特定范围内的数据信息。实现对数据库表中数据的修改操作,即可以修改已经存储的宠物投喂器上传的数据。实现对数据库表中数据的删除操作,即可以删除已经存储的宠物投喂器上传的数据。二、SQLite数据库

SQLite是一款轻量级、开源的嵌入式关系型数据库管理系统(RDBMS),设计目标是嵌入式设备或应用程序使用。与传统的客户端/服务器模式不同,SQLite引擎不是一个独立的进程,而是被集成在一个应用程序中。应用程序可以访问SQLite数据库文件,读写其中的数据,从而实现数据的存储和管理。


(资料图片)

以下是 SQLite 数据库的特点:

轻量级:SQLite 占用资源较小,运行速度快,并且可以很方便地集成到应用程序中,使其成为一个内嵌的数据库。无需服务器:SQLite 是一款本地化的数据库,无需专门的服务器进行支持,因此对于小型应用程序来说,是一种非常适合的解决方案。开源:SQLite 是一款开源的数据库,用户可以免费获取其源代码,并且可以自由地进行修改和定制。支持 SQL:SQLite 支持完整的 SQL 标准,并且在 SQL 语法和命令方面与其他关系型数据库非常接近,具有较高的兼容性。可移植性:SQLite 支持多种操作系统编程语言,如 Windows、Linux、Mac OS X、iOSAndroid等平台,以及 C/C++JavaPythonC#等编程语言。数据库存储方式: SQLite 将数据库存储在单个文件中,用户可以根据需要将其复制或移动到其他位置或计算机中,以方便数据的安全备份和分享。三、在Qt里使用SQLITE数据库

在 Qt 中,使用 SQLite 数据库的主要流程如下:

(1)导入 SQLite 相关库文件:在 Qt 项目中,需要先导入 SQLite 相关的库文件和头文件,以便在代码中使用 SQLite 的相关函数和类。

需要在项目文件中添加以下语句:

QT += sql

这样就可以包含 SQLite 数据库支持的相关头文件和类。

(2)创建数据库连接:使用 QSqlDatabase 类可以在 Qt 中创建一个数据库连接。需要设置数据库类型(如 "QSQLITE"),以及数据库文件路径等参数。

代码示例如下:

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("mydatabase.db");

在实际使用时,可以使用绝对或相对路径指定数据库文件路径。

(3)打开数据库:使用 QSqlDatabase 类的 open 函数可以打开数据库连接。在成功打开数据库后,可以执行 SQL 查询语句,读取和修改数据库中的数据。

代码示例:

if(db.open()) {     QSqlQuery query;     query.exec("CREATETABLE mytable (id INTEGER PRIMARY KEY, name TEXT)");     query.exec("INSERT INTO mytable VALUES(1, "John")");     query.exec("SELECT id, name FROM mytable");     while(query.next()) {         int id = query.value(0).toInt();         QString name = query.value(1).toString();         qDebug() < < id < < name;     } }

以上代码创建了一个名为 "mytable" 的数据库表,并向其中插入了一条记录。随后,执行 SELECT 查询语句读取表中的数据,并将结果输出到控制台中。

(4)关闭数据库:当不再需要使用数据库时,应该使用 close 函数关闭数据库连接,以释放资源。

代码示例:

db.close();

在以上流程中,使用 QSqlQuery 类可以执行 SQL 查询语句,并获取查询结果。通过 QSqlRecord 类可以访问查询结果中的字段和值。

四、完整代码

下面是 Qt(C++)中利用 SQLite 数据库对宠物投喂器上传的数据进行存储管理的实现代码,包括数据的增删改查功能:

#include < QtSql > #include < QDebug > ​ // 创建或打开数据库连接 bool createConnection() {     QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");     db.setDatabaseName("petfeeder.db");     if (!db.open()) {         qDebug() < < "Failedto connect database.";         return false;     }     // 创建 petfeeder 表     QSqlQuery query;     bool ret = query.exec("CREATE TABLE IF NOT EXISTS petfeeder "                            "(id INTEGER PRIMARY KEY AUTOINCREMENT, "                            "interval INTEGER, temperature REAL, weight REAL)");     if (!ret) {         qDebug() < < "Failed to create table: " < < query.lastError().text();     }     return true; } ​ // 插入数据 void insertData(int interval, double temperature, double weight) {     QSqlQuery query;     QString sql = QString("INSERT INTO petfeeder (interval, temperature, weight) "                           "VALUES (%1, %2, %3)").arg(interval).arg(temperature).arg(weight);     bool ret = query.exec(sql);     if (!ret) {         qDebug() < < "Failed to insert data: " < < query.lastError().text();     } } ​ // 更新数据 void updateData(int id, int interval, double temperature, double weight) {     QSqlQuery query;     QString sql = QString("UPDATE petfeeder SET interval=%1, temperature=%2, weight=%3 "                           "WHERE id=%4").arg(interval).arg(temperature).arg(weight).arg(id);     bool ret = query.exec(sql);     if (!ret) {         qDebug() < < "Failed to update data: " < < query.lastError().text();     } } ​ // 删除数据 void deleteData(int id) {     QSqlQuery query;     QString sql = QString("DELETE FROM petfeeder WHERE id=%1").arg(id);     bool ret = query.exec(sql);     if (!ret) {         qDebug() < < "Failed to delete data: " < < query.lastError().text();     } } ​ // 查询数据 void queryData() {     QSqlQuery query("SELECT * FROM petfeeder");     while (query.next()) {         int id = query.value(0).toInt();         int interval = query.value(1).toInt();         double temperature = query.value(2).toDouble();         double weight = query.value(3).toDouble();         qDebug() < < "Id:" < < id < < "Interval:" < < interval < < "Temperature:" < < temperature < < "Weight:" < < weight;     } } ​ // 主函数 int main() {     if (!createConnection()) {         return 1;     }     // 插入数据     insertData(3, 25.5, 0.2);     insertData(2, 26, 0.3);     insertData(4, 24, 0.4);     // 查询数据     queryData();     // 更新数据     updateData(2, 4, 27, 0.3);     // 删除数据     deleteData(3);     // 查询数据     queryData(); ​     return 0; }

在上面代码里,使用 createConnection函数创建或打开数据库连接,创建名为 petfeeder 的数据表。使用 insertData函数向数据表中插入数据,使用 updateData函数更新数据,使用 deleteData函数删除数据,使用 queryData函数查询数据,将结果输出到控制台。

审核编辑 黄宇

标签:

上一篇:每日简讯:在AIGC魔法世界里,你是麻瓜吗?
下一篇:最后一页