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

相关推荐

  1. QT开发(动态数据采集与监控)

    2024-01-04 16:49:56       31 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-04 16:49:56       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-04 16:49:56       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-04 16:49:56       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-04 16:49:56       20 阅读

热门阅读

  1. Invoke和BeginInvoke的区别

    2024-01-04 16:49:56       30 阅读
  2. SpringBoot之项目管理

    2024-01-04 16:49:56       38 阅读
  3. PAT乙级1038 统计同成绩学生

    2024-01-04 16:49:56       34 阅读
  4. 用python实现打飞机游戏

    2024-01-04 16:49:56       37 阅读
  5. 【C程序设计】C作用域

    2024-01-04 16:49:56       41 阅读
  6. 序列化与反序列化xml bin

    2024-01-04 16:49:56       37 阅读
  7. 好用的的抓包工具,Wireshark、whistle

    2024-01-04 16:49:56       51 阅读
  8. KNN 回归

    2024-01-04 16:49:56       36 阅读
  9. Git 忽略提交 .gitignore

    2024-01-04 16:49:56       41 阅读