数据查询模块在整个系统中难度最低,因为Qt对数据库操做的封装堪称完美,因此各类查询都是手到擒来,不费吹灰之力。Qt中内置了sqlite数据库,你能够在数据库插件目录sqldrivers发现qsqlite.dll文件比较大,大概800KB左右,而qsqlmysql.dll才70KB,按道理mysql确定比sqlite要大才对,后面查阅资料发现越来Qt源码中已经包含了sqlite的源码,编译的时候直接内置进去了。这样就大大方便用户使用sqlite数据库了,不像mysql等其余数据库还须要带上对应数据库的动态库文件。其实安卓系统中也大量使用sqlite数据库,足以见得sqlite数据库是有多么的方便。Qt中的数据库通讯都在qtsql模块中,主要经常使用的就是qsqlquery和qsqltablemodel这两个类了,一个用来执行sql语句,别看qsqlquery字面上的意思是查询,其实还包括了添加、删除、修改(基本术语简称增删改)等,反正他能够执行任意的sql语句,只要数据库支持的话,若是有结果返回,会提供一个结果集返回,能够循环遍历取出结果。数据库处理基本上是四个点叫增删改查,这些都是对应的sql语句,具体sql教程推荐能够看这里https://www.w3school.com.cn/sql/index.asp。我的作数据库相关的项目以来,除了基本的增删改查之外,基本上就是要注意三点:第一点索引,第二点数据库事务,第三点数据库翻页。mysql
第一点索引,说到数据库查询,不得不说很重要的东西,那就是索引,不少初学者都反应查询好慢啊,才几十万的数据量,就慢成这样子,一问原来没有加索引的缘故,这个知识点通用于任何开发语言而并非qt独有,这是数据库相关的知识点,强烈建议在数据库建表的时候,若是是经常使用的须要查询的表,尤为是用到where条件语句的表,必须加上索引,至于索引的字段,建议使用经常使用的条件的字段,这样在查询的时候速度飞快,索引就至关于新华字典的部首目录或者音节目录,这样能够快速定位具体位置。linux
第二点数据库事务,加了索引查询是变快了不少,在这种几十万的数据量下,基本上是瞬间忽略不计,也要看具体的字段的数量和每一个字段的字节数长度等,若是是几百个字段,那另当别论,不过通常不建议一个表的字段数量特别多,那样无法管理,太难了。索引是加快了查询速度,也会带来一些负面影响好比数据库文件体积变大,基本上会变大50%,不过如今的存储器那么大,基本上没有太大关系,查询是快了,不少初学者又抱怨这Qt真垃圾,添加几百条数据要好久好久,若是是几千条更是卡爆了,这个又是另一个重要知识点数据库事务,通常对于大量的数据更新,好比插入数据或者更新数据等,建议开启数据库事务,这样处理之后哪怕一次性插入一万条数据,也是很是快的。代码以下:git
//启动数据库事务 QSqlDatabase::database().transaction(); int count = sqls.count(); for (int i = 0; i < count; i++) { QSqlQuery query; query.exec(sqls.at(i)); } //提交数据库事务 bool ok = QSqlDatabase::database().commit(); if (!ok) { QSqlDatabase::database().rollback(); }
第三点数据库翻页,因为常常作数据库相关的项目,其实大部分的项目,注意只要是项目不是那种调试工具级别的小demo,多多少少都会涉及到记录存储等,这就须要用到数据库,记录查询这块,少不了分页显示查询结果,不论是何种开发语言,各类程序员都会封装本身的一套通用的数据库翻页代码,毫无疑问我也封装了一套轮子,重复利用,我甚至封装了上一页下一页按钮+当前记录数等标签的功能,只要传入对应控件的指针便可,此代码开源。程序员
通用翻页组件源码地址:https://gitee.com/feiyangqingyun/QWidgetDemo https://github.com/feiyangqingyun/QWidgetDemo
文件名称:dbpagegithub
体验地址:https://gitee.com/feiyangqingyun/QWidgetExe https://github.com/feiyangqingyun/QWidgetExe
文件名称:bin_sams.zipweb
void frmDataNode::initData() { whereSql = "where 1=1"; columnNames << "编号" << "位号" << "控制器名称" << "探测器名称" << "浓度值" << "气体符号" << "保存时间"; columnWidths << 60 << 100 << 130 << 130 << 60 << 70 << 150; if (App::WorkMode == 2) { columnNames[5] = "符号"; } //设置须要显示数据的表格和翻页的按钮,最后一列自动填充,奇偶行不一样颜色显示 dbPage = new DbPage(this); dbPage->setAllCenter(true); dbPage->setColumnNames(columnNames); dbPage->setColumnWidths(columnWidths); dbPage->setResultCurrent(App::PageCount); dbPage->setTableName("NodeLog"); dbPage->setOrderSql(QString("LogID %1").arg(App::NodeLogOrder)); dbPage->setControl(ui->tableView, ui->labPageCount, ui->labPageCurrent, ui->labResultCount, ui->labResultCurrent, ui->labResult, 0, ui->btnFirst, ui->btnPre, ui->btnNext, ui->btnLast, "LogID"); dbPage->setWhereSql(whereSql); dbPage->select(); } void frmDataNode::on_btnSelect_clicked() { QDateTime dateStart = ui->dateStart->dateTime(); QDateTime dateEnd = ui->dateEnd->dateTime(); if (dateStart > dateEnd) { QUIHelper::showMessageBoxError("开始时间不能大于结束时间!", 3); return; } //构建SQL语句 QString sql = "where 1=1"; if (ui->ckTimeStart->isChecked()) { if (App::LocalDBType.toUpper() == "SQLITE") { sql += " and datetime(SaveTime)>='" + dateStart.toString("yyyy-MM-dd HH:mm:ss") + "'"; sql += " and datetime(SaveTime)<='" + dateEnd.toString("yyyy-MM-dd HH:mm:ss") + "'"; } else if (App::LocalDBType.toUpper() == "MYSQL") { sql += " and unix_timestamp(SaveTime)>=unix_timestamp('" + dateStart.toString("yyyy-MM-dd HH:mm:ss") + "')"; sql += " and unix_timestamp(SaveTime)<=unix_timestamp('" + dateEnd.toString("yyyy-MM-dd HH:mm:ss") + "')"; } } if (ui->ckDeviceName->isChecked()) { sql += " and DeviceName='" + ui->cboxDeviceName->currentText() + "'"; } if (ui->ckNodeName->isChecked()) { sql += " and NodeName='" + ui->cboxNodeName->currentText() + "'"; } if (ui->ckPositionID->isChecked()) { sql += " and PositionID='" + ui->txtPositionID->text() + "'"; } //绑定数据到表格 whereSql = sql; dbPage->setWhereSql(whereSql); dbPage->select(); }