真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Qt數(shù)據(jù)查詢怎么寫

本篇內(nèi)容主要講解“Qt數(shù)據(jù)查詢怎么寫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Qt數(shù)據(jù)查詢怎么寫”吧!

站在用戶的角度思考問題,與客戶深入溝通,找到漳州網(wǎng)站設(shè)計與漳州網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬主機、企業(yè)郵箱。業(yè)務(wù)覆蓋漳州地區(qū)。

一、前言

數(shù)據(jù)查詢模塊在整個系統(tǒng)中難度最低,由于Qt對數(shù)據(jù)庫操作的封裝堪稱完美,所以各種查詢都是手到擒來,不費吹灰之力。Qt中內(nèi)置了sqlite數(shù)據(jù)庫,你可以在數(shù)據(jù)庫插件目錄sqldrivers發(fā)現(xiàn)qsqlite.dll文件比較大,大概800KB左右,而qsqlMySQL.dll才70KB,按道理mysql肯定比sqlite要大才對,后面查閱資料發(fā)現(xiàn)越來Qt源碼中已經(jīng)包含了sqlite的源碼,編譯的時候直接內(nèi)置進(jìn)去了。這樣就大大方便用戶使用sqlite數(shù)據(jù)庫了,不像mysql等其他數(shù)據(jù)庫還需要帶上對應(yīng)數(shù)據(jù)庫的動態(tài)庫文件。其實安卓系統(tǒng)中也大量使用sqlite數(shù)據(jù)庫,足以見得sqlite數(shù)據(jù)庫是有多么的方便。Qt中的數(shù)據(jù)庫通信都在qtsql模塊中,主要常用的就是qsqlquery和qsqltablemodel這兩個類了,一個用來執(zhí)行sql語句,別看qsqlquery字面上的意思是查詢,其實還包括了添加、刪除、修改(基本術(shù)語簡稱增刪改)等,反正他可以執(zhí)行任意的sql語句,只要數(shù)據(jù)庫支持的話,如果有結(jié)果返回,會提供一個結(jié)果集返回,可以循環(huán)遍歷取出結(jié)果。代碼如下:

//啟動數(shù)據(jù)庫事務(wù)
QSqlDatabase::database().transaction();

int count = sqls.count();
for (int i = 0; i < count; i++) {
    QSqlQuery query;
    query.exec(sqls.at(i));
}

//提交數(shù)據(jù)庫事務(wù)
bool ok = QSqlDatabase::database().commit();
if (!ok) {
    QSqlDatabase::database().rollback();
}

第三點數(shù)據(jù)庫翻頁,由于經(jīng)常做數(shù)據(jù)庫相關(guān)的項目,其實大部分的項目,注意只要是項目不是那種調(diào)試工具級別的小demo,多多少少都會涉及到記錄存儲等,這就需要用到數(shù)據(jù)庫,記錄查詢這塊,少不了分頁顯示查詢結(jié)果,不管是何種開發(fā)語言,各種程序員都會封裝自己的一套通用的數(shù)據(jù)庫翻頁代碼,毫無疑問我也封裝了一套輪子,重復(fù)利用,我甚至封裝了上一頁下一頁按鈕+當(dāng)前記錄數(shù)等標(biāo)簽的功能,只要傳入對應(yīng)控件的指針即可,此代碼開源。

二、功能特點

  1. 采集數(shù)據(jù)端口,支持串口端口+網(wǎng)絡(luò)端口,串口支持自由設(shè)置串口號+波特率,網(wǎng)絡(luò)支持自由設(shè)置IP地址+通訊端口,每個端口支持采集周期,默認(rèn)1秒鐘一個地址,支持設(shè)置通訊超時次數(shù),默認(rèn)3次,支持最大重連時間,用于重新讀取離線的設(shè)備。

  2. 控制器信息,能夠添加控制器名稱,選擇控制器地址+控制器型號,設(shè)置該控制器下面的探測器數(shù)量。

  3. 探測器信息,能夠添加位號,可自由選擇探測器型號,氣體種類,氣體符號,高報值,低報值,緩沖值,清零值,是否啟用,報警聲音,背景地圖,存儲周期,數(shù)值換算小數(shù)點位數(shù),報警延時時間,報警的類型(HH,LL,HL)等。

  4. 控制器型號+探測器型號+氣體種類+氣體符號,均可自由配置。

  5. 地圖支持導(dǎo)入和刪除,所有的探測器對應(yīng)地圖位置可自由拖動保存。

  6. 端口信息+控制器信息+探測器信息,支持導(dǎo)入導(dǎo)出+導(dǎo)出到excel+打印。

  7. 運行記錄+報警記錄+用戶記錄,支持多條件組合查詢,比如時間段+控制器+探測器等,所有記錄支持導(dǎo)出到excel+打印。

  8. 導(dǎo)出到excel的記錄支持所有excel+wps等表格文件版本,不依賴excel等軟件。

  9. 可刪除指定時間范圍內(nèi)的數(shù)據(jù),支持自動清理早期數(shù)據(jù),設(shè)置最大保存記錄數(shù)。

  10. 支持報警短信轉(zhuǎn)發(fā),支持多個接收手機號碼,可設(shè)定發(fā)送間隔,比如即時發(fā)送或者6個小時發(fā)送一次所有的報警信息,短信內(nèi)容過長,自動拆分多條短信。

  11. 支持報警郵件轉(zhuǎn)發(fā),支持多個接收郵箱,可設(shè)定發(fā)送間隔,比如即時發(fā)送或者6個小時發(fā)送一次所有的報警信息,支持附件發(fā)送。

  12. 高報顏色+低報顏色+正常顏色+0值顏色+曲線背景+曲線顏色等,都可以自由選擇。

  13. 軟件的中文標(biāo)題+英文標(biāo)題+logo路徑+版權(quán)所有都可以自由設(shè)置。

  14. 提供開關(guān)設(shè)置開機運行+報警聲音+自動登錄+記住密碼等。

  15. 報警聲音可設(shè)置播放次數(shù),界面提供17種皮膚文件選擇。

  16. 支持云端數(shù)據(jù)同步,可設(shè)置云端數(shù)據(jù)庫的信息,比如數(shù)據(jù)庫名稱,用戶名+密碼等。

  17. 支持網(wǎng)絡(luò)轉(zhuǎn)發(fā)和網(wǎng)絡(luò)接收,網(wǎng)絡(luò)接收開啟后,軟件從udp接收數(shù)據(jù)進(jìn)行解析。網(wǎng)絡(luò)轉(zhuǎn)發(fā)支持多個目標(biāo)IP,這樣就實現(xiàn)了本地采集的軟件,自由將數(shù)據(jù)轉(zhuǎn)到客戶端,隨時查看探測器數(shù)據(jù)。

  18. 自動記住用戶最后停留的界面+其他信息,重啟后自動應(yīng)用。

  19. 報警自動切換到對應(yīng)的地圖,探測器按鈕閃爍。

  20. 雙擊探測器圖標(biāo),可以進(jìn)行回控。

  21. 支持用戶權(quán)限管理,管理員+操作員兩大類,用戶登錄+用戶退出,可以記住密碼和自動登錄,超過三次報錯提示并關(guān)閉程序。

  22. 支持四種監(jiān)控模式,設(shè)備面板監(jiān)控+地圖監(jiān)控+表格數(shù)據(jù)監(jiān)控+曲線數(shù)據(jù)監(jiān)控,可自由切換,四種同步應(yīng)用。

  23. 支持報警繼電器聯(lián)動,一個位號可以跨串口聯(lián)動多個模塊和繼電器號,支持多對多。

  24. 本地數(shù)據(jù)存儲支持sqlite+mysql,支持遠(yuǎn)程數(shù)據(jù)同步到云端數(shù)據(jù)庫。自動重連。

  25. 本地設(shè)備采集到的數(shù)據(jù)實時上傳到云端,以便手機APP或者web等其他方式提取。

  26. 支持兩種數(shù)據(jù)源,一種是串口和網(wǎng)絡(luò)通過協(xié)議采集設(shè)備數(shù)據(jù),一種是數(shù)據(jù)庫采集。數(shù)據(jù)庫采集模式可以作為通用的系統(tǒng)使用。

  27. 自帶設(shè)備模擬工具,支持16個設(shè)備數(shù)據(jù)模擬,同時還帶數(shù)據(jù)庫數(shù)據(jù)模擬,以便在沒有設(shè)備的時候測試數(shù)據(jù)。

  28. 默認(rèn)通信協(xié)議采用modbus協(xié)議,后期增加mqtt等物聯(lián)網(wǎng)協(xié)議的支持,做成通用系統(tǒng)。

  29. 支持所有windows操作系統(tǒng)+linux操作系統(tǒng)和其他操作系統(tǒng)。

三、效果圖

Qt數(shù)據(jù)查詢怎么寫

四、核心代碼

void frmDataNode::initData()
{
    whereSql = "where 1=1";
    columnNames << "編號" << "位號" << "控制器名稱" << "探測器名稱" << "濃度值" << "氣體符號" << "保存時間";
    columnWidths << 60 << 100 << 130 << 130 << 60 << 70 << 150;

    if (App::WorkMode == 2) {
        columnNames[5] = "符號";
    }

    //設(shè)置需要顯示數(shù)據(jù)的表格和翻頁的按鈕,最后一列自動填充,奇偶行不同顏色顯示
    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("開始時間不能大于結(jié)束時間!", 3);
        return;
    }

    //構(gòu)建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() + "'";
    }

    //綁定數(shù)據(jù)到表格
    whereSql = sql;
    dbPage->setWhereSql(whereSql);
    dbPage->select();
}

到此,相信大家對“Qt數(shù)據(jù)查詢怎么寫”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


網(wǎng)頁題目:Qt數(shù)據(jù)查詢怎么寫
本文網(wǎng)址:http://weahome.cn/article/gjppse.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部