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的学习还是比较方便、比较简单的,十分适合用于上位机的开发和应用。

相关推荐
sdaxue.com6 分钟前
帝国CMS:如何去掉帝国CMS登录界面的认证码登录
数据库·github·网站·帝国cms·认证码
o(╥﹏╥)1 小时前
linux(ubuntu )卡死怎么强制重启
linux·数据库·ubuntu·系统安全
阿里嘎多学长1 小时前
docker怎么部署高斯数据库
运维·数据库·docker·容器
Yuan_o_1 小时前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
Sunyanhui11 小时前
牛客网 SQL36查找后排序
数据库·sql·mysql
老王笔记1 小时前
MHA binlog server
数据库·mysql
lovelin+v175030409662 小时前
安全性升级:API接口在零信任架构下的安全防护策略
大数据·数据库·人工智能·爬虫·数据分析
DT辰白3 小时前
基于Redis的网关鉴权方案与性能优化
数据库·redis·缓存
2401_871213303 小时前
mysql高阶语句
数据库·mysql