C++ Qt开发:Charts与数据库组件联动.docx
第
C++Qt开发:Charts与数据库组件联动
Qt是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍Charts组件与QSql数据库组件的常用方法及灵活运用。
在之前的文章中详细介绍了关于QCharts绘图组件的使用方式,本章将继续延续这个知识点,通过使用QSql数据库模块动态的读取某一个时间节点上的数据,当用户点击查询数据时则动态的输出该事件节点的所有数据,并将数据绘制到图形组件内,实现动态查询图形的功能。
首先我们需要生成一些测试数据,在文章课件中有一个InitDatabase案例,该案例中通过QSql组件动态创建一个Times表,该表中有三个字段分别记录了主机IP地址、时间、以及数据,并动态的想表中插入一些随机测试数据,读者可运行这段程序并等待十分钟以上,此时数据库database.sqlite3中将会出现如下所示的数据集;
再来看下主窗体是如何设计的,左侧使用一个ComboBox下拉选择框,右侧使用两个可自由调节的Date/TimeEdit组件,最底部则是一个graphicsView绘图组件,如下图;
由于涉及到IP地址的选择,所以在MAInWindow主构造函数中我们需要对ComboBox组件进行初始化,在初始化时我们需要打开数据库并将数据库中的Times表,并查询到address字段,这里在查询语句中使用DISTINCT语句,该语句是用于在SQL查询中选择唯一值的关键字,它能够确保查询的结果集中每个列的值都是唯一的。
SELECTDISTINCTaddressFROMTimes;
在代码中,上述查询的目的是从Times表中选择唯一的address列的值。如果Times表中有多个行具有相同的address值,DISTINCT会确保在结果中只返回一个该值,以避免重复。
当具备了这条语句那么查询唯一值将变得非常容易,当查询到对应值只有只需要通过comboBox-addItem即可将唯一的IP地址追加到组件中,如下代码所示;
MainWindow::MainWindow(QWidget*parent):QMainWindow(parent),ui(newUi::MainWindow)
ui-setupUi(this);
//初始化绘图
InitLineChart();
//初始化时间组件
QDateTimecurDateTime=QDateTime::currentDateTime();
//设置当前时间
ui-dateTimeEdit_Start-setDateTime(curDateTime);
ui-dateTimeEdit_End-setDateTime(curDateTime);
//设置时间格式
ui-dateTimeEdit_Start-setDisplayFormat(yyyy-MM-ddhh:mm:ss
ui-dateTimeEdit_End-setDisplayFormat(yyyy-MM-ddhh:mm:ss
//初始化数据库
db=QSqlDatabase::addDatabase(QSQLITE
db.setDatabaseName(database.sqlite3
if(!db.open())
std::coutdb.lastError().text().toStdString()std::endl;
return;
//查询数据库中的IP地址信息
QSqlQueryquery;
if(query.exec(SELECTDISTINCTaddressFROMTimes;))
QSetQStringuniqueAddresses;
while(query.next())
//Assumingaddressisthenameofthecolumn
QStringdata_name=query.value(0).toString();
uniqueAddresses.insert(data_name);
//清空现有的项
ui-comboBox-clear();
//将唯一地址添加到QComboBox中
foreach(constQStringunique