QT上位机开发(数据库sqlite编程)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

编写软件的时候,如果用户的数据比较少,那么用json保存是非常方便的。但是一旦数据量大了之后,建议还是用数据库来进行管理比较好。数据库在增、删、改、查这方面还是比较好用的。目前,有一种小型的开源数据库sqlite,特别适合大家来使用。它是嵌入在软件程序里面的。和mysql不一样,mysql是单独一个数据库服务器。

1、qt对sqlite的支持

本身qt可以直接访问sqlite数据库,引用头文件的时候,直接输入QtSql即可,如下所示,

复制代码
#include <QtSql/QtSql>

2、链接时的注意事项

默认,qt是没有把QtSql的lib放入到链接库当中的,所以这部分需要自己手动来完成,如下所示,

3、测试方法

首先我们可以创建一个简单的qt widget工程。在界面部分不需要再做任何的修改,所以也就不需要designer的参与。代码部分呢,可以编写一个loadDB的类函数。在这个类函数里面,为了测试sqlite的功能,我们可以做一些增、删、改、查的操作,如果所有的操作都是ok的,那就代表测试代码是正确的、没问题的。

4、loadDB函数的编写

测试的过程基本是这样的。首先,利用QSqlDatabase创建一个data.db的数据库。有了这个数据库之后,打开数据库。接下来用QSqlQuery进行第一个操作,就是创建一张mytable的表。有了表之后,我们就可以插入数据、查询数据、更改数据、查询数据、删除数据、查询数据,总共是6个动作。所有动作都做完毕之后,就可以关闭数据库了。在数据库操作的过程当中,还可以通过qDebug打印的办法来判断操作是否正确。qDebug打印的地方就在输出窗口里面,如下所示,

整个测试的源代码是这样的,

复制代码
int QtWidgetsApplication::loadDB()
{
	// create database
	QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
	db.setDatabaseName("data.db");

	// open database
	if (!db.open()) {
		qDebug() << "Error: Unable to open database";
		return 1;
	}

	// execute query
	QSqlQuery query;

	// create a table
	if (!query.exec("CREATE TABLE IF NOT EXISTS mytable (id INTEGER PRIMARY KEY, name TEXT)")) {
		qDebug() << "Error: Unable to create table";
		return 1;
	}

	// insert data
	if (!query.exec("INSERT INTO mytable (name) VALUES ('John Doe')")) {
		qDebug() << "Error: Unable to insert data";
		return 1;
	}

	// query data
	if (query.exec("SELECT * FROM mytable")) {
		qDebug() << "Records in mytable:";
		while (query.next()) {
			int id = query.value(0).toInt();
			QString name = query.value(1).toString();
			qDebug() << "ID:" << id << "Name:" << name;
		}
	}
	else {
		qDebug() << "Error: Unable to fetch data";
		return 1;
	}

	// update data
	if (!query.exec("UPDATE mytable SET name='Jane Doe' WHERE id=1")) {
		qDebug() << "Error: Unable to update data";
		return 1;
	}

	// query data after update
	if (query.exec("SELECT * FROM mytable")) {
		qDebug() << "Records in mytable after update:";
		while (query.next()) {
			int id = query.value(0).toInt();
			QString name = query.value(1).toString();
			qDebug() << "ID:" << id << "Name:" << name;
		}
	}
	else {
		qDebug() << "Error: Unable to fetch data";
		return 1;
	}

	// delete data
	if (!query.exec("DELETE FROM mytable WHERE id=1")) {
		qDebug() << "Error: Unable to delete data";
		return 1;
	}

	// query after delete
	if (query.exec("SELECT * FROM mytable")) {
		qDebug() << "Records in mytable after delete:";
		while (query.next()) {
			int id = query.value(0).toInt();
			QString name = query.value(1).toString();
			qDebug() << "ID:" << id << "Name:" << name;
		}
	}
	else {
		qDebug() << "Error: Unable to fetch data";
		return 1;
	}

	// close connection of database
	db.close();
}

有兴趣的同学可以按照这个流程完整地走一遍。这样就可以在后面的项目中灵活使用sqlite了。一般项目中,使用到的业务要复杂一点,也有可能不止一张表,但是对数据库操作的逻辑都是这样的,没有什么区别。整体来说,sqlite的学习还是比较方便、比较简单的,十分适合用于上位机的开发和应用。

相关推荐
Nturmoils5 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波9 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡6 天前
【MySQL数据库】数据类型与表约束
数据库·mysql