SQLite数据库实现数据增删改查

news/2025/3/14 18:19:16/

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

实现功能:

  • 创建 SQLite 数据库表,用于存储宠物投喂器上传的数据。

  • 实现对数据库表中数据的插入操作,即将从宠物投喂器接收到的数据存储到数据库中。

  • 实现对数据库表中数据的查询操作,包括按照投喂间隔时间、水温、剩余重量等参数进行筛选,以便用户能够查看特定范围内的数据信息。

  • 实现对数据库表中数据的修改操作,即可以修改已经存储的宠物投喂器上传的数据。

  • 实现对数据库表中数据的删除操作,即可以删除已经存储的宠物投喂器上传的数据。

二、SQLite数据库

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

以下是 SQLite 数据库的特点:

  • 轻量级:SQLite 占用资源较小,运行速度快,并且可以很方便地集成到应用程序中,使其成为一个内嵌的数据库。

  • 无需服务器:SQLite 是一款本地化的数据库,无需专门的服务器进行支持,因此对于小型应用程序来说,是一种非常适合的解决方案。

  • 开源:SQLite 是一款开源的数据库,用户可以免费获取其源代码,并且可以自由地进行修改和定制。

  • 支持 SQL:SQLite 支持完整的 SQL 标准,并且在 SQL 语法和命令方面与其他关系型数据库非常接近,具有较高的兼容性。

  • 可移植性:SQLite 支持多种操作系统和编程语言,如 Windows、Linux、Mac OS X、iOS、Android 等平台,以及 C/C++、Java、Python、C# 等编程语言。

  • 数据库存储方式: 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("CREATE TABLE 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() << "Failed to 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 函数查询数据,将结果输出到控制台。


http://www.ppmy.cn/news/1036921.html

相关文章

前端JavaScript企业框架的全面解析

引言 在现代Web开发中&#xff0c;前端JavaScript框架扮演着至关重要的角色。它们提供了丰富的功能和工具&#xff0c;帮助开发人员构建功能强大且易于维护的企业级应用程序。本篇博客将全面解析前端JavaScript企业框架&#xff0c;介绍其优势、使用场景和常见的框架选择。 什…

力扣初级算法(数组拆分)

力扣初级算法&#xff08;数组拆分&#xff09; 每日一算法&#xff1a; 力扣初级算法&#xff08;数组拆分&#xff09; 学习内容&#xff1a; 1.问题描述 给定长度为 2n 的整数数组 nums &#xff0c;你的任务是将这些数分成 n 对, 例如 (a1, b1), (a2, b2), …, (an, bn) …

Java基础(十三)面向对象编程 OOP

Java面向对象基础知识笔记&#xff08;二&#xff09; 1. this关键字 this 关键字代表当前对象的引用&#xff0c;可以用于访问当前对象的成员变量、成员方法和构造方法。在以下情况下常用到 this&#xff1a; 使用 this 调用成员变量&#xff0c;解决成员变量与局部变量的同…

第八章 CUDA内存应用与性能优化篇(上篇)

cuda教程目录 第一章 指针篇 第二章 CUDA原理篇 第三章 CUDA编译器环境配置篇 第四章 kernel函数基础篇 第五章 kernel索引(index)篇 第六章 kenel矩阵计算实战篇 第七章 kenel实战强化篇 第八章 CUDA内存应用与性能优化篇 第九章 CUDA原子(atomic)实战篇 第十章 CUDA流(strea…

Spring学习笔记之Bean的“出生入死”

文章目录 什么是Bean的生命周期为什么要知道Bean的生命周期Bean的生命周期之五个阶段Bean生命周期之七个阶段Bean生命周期的十个阶段Bean的作用域不同&#xff0c;管理方式不同自己new的对象如何让Spring管理 什么是Bean的生命周期 Spring其实就是一个管理Bean对象的工厂。它负…

Java多线程(4)---死锁和Synchronized加锁流程

目录 前言 一.synchronized 1.1概念 1.2Synchronized是什么锁&#xff1f; 1.3Synchronized加锁工作过程 1.4其他优化操作 二.死锁 2.1什么是死锁 2.2死锁的几个经典场景 2.3死锁产生的条件 2.4如何解决死锁 &#x1f381;个人主页&#xff1a;tq02的博客_CSDN博客…

前端跨域的原因以及解决方案(vue),一文让你真正理解跨域

跨域这个问题,可以说是前端的必需了解的,但是多少人是知其然不知所以然呢&#xff1f; 下面我们来梳理一下vue解决跨域的思路。 什么情况会跨域&#xff1f; ​ 跨域的本质就是浏览器基于同源策略的一种安全手段。所谓同源就是必须有以下三个相同点&#xff1a;协议相同、域名…

FreeRTOS qemu mps2-an385 bsp 移植制作 :系统运行篇

相关文章 FreeRTOS qemu mps2-an385 bsp 移植制作 &#xff1a;环境搭建篇 FreeRTOS qemu mps2-an385 bsp 移植制作 &#xff1a;系统启动篇 开发环境 Win10 64位 VS Code&#xff0c;ssh 远程连接 ubuntu VMware Workstation Pro 16 Ubuntu 20.04 FreeRTOSv202212.01&a…