欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C/C++ Qt 數(shù)據(jù)庫與Chart歷史數(shù)據(jù)展示

 更新時間:2021年12月11日 16:14:57   作者:LyShark  
這篇文章主要介紹了Qt利用Qchart組件展示數(shù)據(jù)庫中的歷史數(shù)據(jù)。文中的示例代碼講解清晰,具有一定的學(xué)習(xí)和工作價值,感興趣的小伙伴可以學(xué)習(xí)一下

在前面的博文中具體介紹了QChart組件是如何繪制各種通用的二維圖形的,本章內(nèi)容將繼續(xù)延申一個新的知識點,通過數(shù)據(jù)庫存儲某一段時間節(jié)點數(shù)據(jù)的走向,當(dāng)用戶通過編輯框提交查詢記錄時,程序自動過濾出該時間節(jié)點下所有的數(shù)據(jù),并將該數(shù)據(jù)動態(tài)繪制到圖形組件內(nèi),實現(xiàn)動態(tài)查詢圖形的功能。

首先通過如下代碼,創(chuàng)建Times表,表內(nèi)記錄有某個主機某個時間節(jié)點下的數(shù)值:

#include <QCoreApplication>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include <QSqlRecord>
#include <iostream>
#include <QStringList>
#include <QString>
#include <QVariant>
#include <QDebug>
#include <QDateTime>
#include <QTime>

// 初始化數(shù)據(jù)庫
// https://www.cnblogs.com/lyshark
void InitSql()
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");

    db.setDatabaseName("lyshark.db");
    if (!db.open())
    {
           std::cout << db.lastError().text().toStdString()<< std::endl;
           return;
    }

   // 執(zhí)行SQL創(chuàng)建表
   db.exec("DROP TABLE Times");
   db.exec("CREATE TABLE Times ("
                   "id INTEGER PRIMARY KEY AUTOINCREMENT, "
                   "address VARCHAR(64) NOT NULL, "
                   "datetime VARCHAR(128) NOT NULL, "
                   "value INTEGER NOT NULL"
           ")"
        );

   db.commit();
   db.close();
}

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    InitSql();
    return a.exec();
}

數(shù)據(jù)庫結(jié)構(gòu)如下:

接著編寫一個模擬插入數(shù)據(jù)的案例,該案例每一秒向數(shù)據(jù)庫內(nèi)插入一條記錄,我們運行一段時間。

#include <QCoreApplication>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include <QSqlRecord>
#include <iostream>
#include <QStringList>
#include <QString>
#include <QVariant>
#include <QDebug>
#include <QDateTime>
#include <QTime>

// 延時函數(shù)
void Sleep(int msec)
{
    QTime dieTime = QTime::currentTime().addMSecs(msec);
    while(QTime::currentTime() < dieTime)
        QCoreApplication::processEvents(QEventLoop::AllEvents,100);
}
// 生成隨機數(shù)
int GetRandom()
{
    int num = qrand() % 100;
    return num;
}

// 插入數(shù)據(jù)
void InsertSQL()
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("lyshark.db");
     if (!db.open())
     {
            std::cout << db.lastError().text().toStdString()<< std::endl;
            return;
     }

     for(int index=0;index <99999;index++)
     {
        QString address = QString("192.168.1.100");
        QDateTime curDateTime = QDateTime::currentDateTime();
        QString date_time = curDateTime.toString("yyyy-MM-dd hh:mm:ss");
        int value = GetRandom();

        QString run_sql = QString("INSERT INTO Times(id,address,datetime,value) VALUES (%1,'%2','%3',%4);")
                                  .arg(index).arg(address).arg(date_time).arg(value);
        std::cout << "執(zhí)行插入語句: " << run_sql.toStdString() << std::endl;

        db.exec(run_sql);
        db.commit();
        Sleep(1000);
     }
     db.close();
}

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));
    InsertSQL();
    return a.exec();
}

運行插入程序,統(tǒng)計一段時間 從 2021-12-11 15:34:16 到 2021-12-11 15:40:04 停止,表內(nèi)記錄如下:

如果我們需要查詢某一個時間節(jié)點下的數(shù)據(jù),例如查詢2021-12-11 15:35:00 - 2021-12-11 15:37:00的數(shù)據(jù)可以這樣寫SQL:

#include <QCoreApplication>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include <QSqlRecord>
#include <iostream>
#include <QStringList>
#include <QString>
#include <QVariant>
#include <QDebug>
#include <QDateTime>
#include <QTime>

// 輸出數(shù)據(jù)
// https://www.cnblogs.com/lyshark
void SelectSQL()
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("lyshark.db");
     if (!db.open())
     {
            std::cout << db.lastError().text().toStdString()<< std::endl;
            return;
     }

    // 查詢數(shù)據(jù)
    QSqlQuery query("SELECT * FROM Times;",db);
    QSqlRecord rec = query.record();

    // 循環(huán)所有記錄
    while(query.next())
    {
        // 判斷當(dāng)前記錄是否有效
        if(query.isValid())
        {
            int id_value = query.value(rec.indexOf("id")).toInt();
            QString address_value = query.value(rec.indexOf("address")).toString();
            QString date_time = query.value(rec.indexOf("datetime")).toString();
            int this_value = query.value(rec.indexOf("value")).toInt();

            if(date_time.toStdString() >= "2021-12-11 15:35:00" && date_time.toStdString() <="2021-12-11 15:37:00")
            {
                std::cout << "value: " << this_value << std::endl;
            }
        }
    }
}

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    SelectSQL();
    return a.exec();
}

這樣就可以將該區(qū)間內(nèi)所有的數(shù)據(jù)全部過濾出來了:

將過濾參數(shù)與QChart組件結(jié)合即可實現(xiàn)動態(tài)繪圖效果,繪制UI界面如下:

當(dāng)用戶點擊查詢時,直接從數(shù)據(jù)庫內(nèi)取出數(shù)據(jù),并將其動態(tài)更新到Chart組件內(nèi)即可,實現(xiàn)代碼如下:

#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include <QSqlRecord>
#include <iostream>
#include <QStringList>
#include <QString>
#include <QVariant>
#include <QDebug>
#include <QDateTime>
#include <QTime>

// 初始化Chart圖表
void MainWindow::InitChart()
{
    // 創(chuàng)建圖表的各個部件
    QChart *chart = new QChart();

    // 將Chart添加到ChartView
    ui->graphicsView->setChart(chart);
    ui->graphicsView->setRenderHint(QPainter::Antialiasing);

    // 隱藏圖例
    chart->legend()->hide();

    // 設(shè)置圖表主題色
    ui->graphicsView->chart()->setTheme(QChart::ChartTheme(1));

    // 創(chuàng)建曲線序列
    QLineSeries *series0 = new QLineSeries();

    // 序列添加到圖表
    chart->addSeries(series0);

    // 創(chuàng)建坐標(biāo)軸
    QValueAxis *axisX = new QValueAxis;    // X軸
    axisX->setRange(1, 100);               // 設(shè)置坐標(biāo)軸范圍
    axisX->setLabelFormat("%d %");         // 設(shè)置X軸格式
    axisX->setMinorTickCount(5);           // 設(shè)置X軸刻度

    QValueAxis *axisY = new QValueAxis;    // Y軸
    axisY->setRange(0, 100);               // Y軸范圍
    axisY->setMinorTickCount(4);           // s設(shè)置Y軸刻度

    // 設(shè)置X于Y軸數(shù)據(jù)集
    chart->setAxisX(axisX, series0);   // 為序列設(shè)置坐標(biāo)軸
    chart->setAxisY(axisY, series0);
}

// 為序列生成數(shù)據(jù)
void MainWindow::SetData()
{
    // 獲取指針
    QLineSeries *series0=(QLineSeries *)ui->graphicsView->chart()->series().at(0);

    // 清空圖例
    series0->clear();

    // 鏈接數(shù)據(jù)庫
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("lyshark.db");
    if (!db.open())
    {
        return;
    }

    // 查詢數(shù)據(jù)
    QSqlQuery query("SELECT * FROM Times;",db);
    QSqlRecord rec = query.record();

    // 賦予數(shù)據(jù)
    qreal t=0,intv=1;

    // 循環(huán)所有記錄
    while(query.next())
    {
        // 判斷當(dāng)前記錄是否有效
        // https://www.cnblogs.com/lyshark
        if(query.isValid())
        {
            QString address_value = query.value(rec.indexOf("address")).toString();
            QString date_time = query.value(rec.indexOf("datetime")).toString();
            int this_value = query.value(rec.indexOf("value")).toInt();

            // 獲取組件字符串
            QString start_user_time = ui->dateTimeEdit_Start->text();
            QString end_user_time = ui->dateTimeEdit_End->text();

            // 將時間字符串轉(zhuǎn)為秒,并計算差值 (秒為單位)
            QDateTime start_timet = QDateTime::fromString(start_user_time, "yyyy-MM-dd hh:mm:ss");
            QDateTime end_timet = QDateTime::fromString(end_user_time, "yyyy-MM-dd hh:mm:ss");

            uint stime = start_timet.toTime_t();
            uint etime = end_timet.toTime_t();

            // 只允許查詢小于180秒的記錄
            uint sub_time = etime - stime;
            if(sub_time <= 180)
            {
                // 查詢指定區(qū)間內(nèi)的數(shù)據(jù)
                if(date_time.toStdString() >= start_user_time.toStdString() && date_time.toStdString() <= end_user_time.toStdString())
                {
                    // std::cout << "區(qū)間內(nèi)的數(shù)據(jù): " << this_value << std::endl;
                    series0->append(t,this_value);
                    t+=intv;
                }
            }
            else
            {
                std::cout << "查詢范圍超出定義." << std::endl;
                return;
            }
        }
    }
}

// 將添加的widget控件件提升為QChartView類
MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    InitChart();

    // 初始化時間組件
    QDateTime curDateTime = QDateTime::currentDateTime();

    // 設(shè)置當(dāng)前時間
    ui->dateTimeEdit_Start->setDateTime(curDateTime);
    ui->dateTimeEdit_End->setDateTime(curDateTime);

    // 設(shè)置時間格式
    ui->dateTimeEdit_Start->setDisplayFormat("yyyy-MM-dd hh:mm:ss");
    ui->dateTimeEdit_End->setDisplayFormat("yyyy-MM-dd hh:mm:ss");
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_pushButton_clicked()
{
    SetData();
}

查詢效果如下所示:

以上就是C/C++ Qt 數(shù)據(jù)庫與Chart歷史數(shù)據(jù)展示的詳細(xì)內(nèi)容,更多關(guān)于C++ Qt?的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • c++截取漢字和英文混合字符串代碼實例

    c++截取漢字和英文混合字符串代碼實例

    這篇文章主要介紹了c++截取漢字英文混合字符串,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Qt控件之QDialog使用及技巧小結(jié)

    Qt控件之QDialog使用及技巧小結(jié)

    QDialog是Qt中的一個類,繼承自QWidget類,用于創(chuàng)建對話框窗口,可以顯示模態(tài)或非模態(tài)的對話框,本文就來介紹一下Qt控件之QDialog使用及技巧小結(jié),感興趣的可以了解一下
    2023-10-10
  • C++命名空間和缺省參數(shù)介紹

    C++命名空間和缺省參數(shù)介紹

    這篇文章主要介紹了C++命名空間和缺省參數(shù),使用命名空間的目的是對標(biāo)識符的名稱進行本地化,以避免命名沖突或名字污染,namespace關(guān)鍵字的出現(xiàn)就是針對這種問題的,缺省參數(shù)是聲明或定義函數(shù)時為函數(shù)的參數(shù)指定一個默認(rèn)值,更多詳細(xì)內(nèi)容需要的小伙伴可以參考下面文章內(nèi)容
    2022-01-01
  • C++采用ring3讀取MBR實例

    C++采用ring3讀取MBR實例

    這篇文章主要介紹了C++采用ring3讀取MBR實例,可實現(xiàn)對硬盤的主引導(dǎo)記錄的讀取,非常具有實用價值,需要的朋友可以參考下
    2014-10-10
  • C語言函數(shù)調(diào)用堆棧詳情分析

    C語言函數(shù)調(diào)用堆棧詳情分析

    這篇文章主要介紹了C語言函數(shù)調(diào)用堆棧詳情分析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • VS2019+Opencv4.0+Win10配置詳解

    VS2019+Opencv4.0+Win10配置詳解

    這篇文章主要介紹了VS2019+Opencv4.0+Win10配置詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • C語言版實現(xiàn)鏈隊列

    C語言版實現(xiàn)鏈隊列

    這篇文章主要為大家詳細(xì)介紹了C語言版實現(xiàn)鏈隊列,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • C++設(shè)計模式之外觀模式

    C++設(shè)計模式之外觀模式

    這篇文章主要介紹了C++設(shè)計模式之外觀模式,本文詳細(xì)講解了C++中的Facade模式,并給出了實例代碼,需要的朋友可以參考下
    2014-10-10
  • C語言單雙線性及循環(huán)鏈表與實例

    C語言單雙線性及循環(huán)鏈表與實例

    這篇文章主要介紹了C語言的單鏈表、雙鏈表和循環(huán)鏈表,還有一些相關(guān)的實例,感興趣的同學(xué)可以借鑒一下
    2023-03-03
  • 簡單講解c++ vector

    簡單講解c++ vector

    這篇文章主要介紹了c++ vector的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下
    2020-09-09

最新評論