小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Qt插入大量數(shù)據(jù)到sqlite數(shù)據(jù)庫,使用事務(wù)提升效率(效率提高的驚人)

 slimfeng 2019-05-05

Qt在操作大量數(shù)據(jù)執(zhí)行插入操作時,推薦使用事務(wù)

1.SQLite數(shù)據(jù)庫本質(zhì)上來講就是一個磁盤上的文件,所以一切的數(shù)據(jù)庫操作其實都會轉(zhuǎn)化為對文件的操作,而頻繁的文件操作將會是一個很好時的過程,會極大地影響數(shù)據(jù)庫存取的速度。例如:向數(shù)據(jù)庫中插入100萬條數(shù)據(jù),在默認(rèn)的情況下如果僅僅是執(zhí)行query.exec(“insert into DataBase(……) values(……)”);就會打開和關(guān)閉文件100萬次,所以速度當(dāng)然會很慢。

2.SQLite數(shù)據(jù)庫是支持事務(wù)操作的,于是我們就可以通過事務(wù)來提高數(shù)據(jù)庫的讀寫速度。事務(wù)的基本原理是:數(shù)據(jù)庫管理系統(tǒng)首先會把要執(zhí)行的sql語句存儲到內(nèi)存當(dāng)中,只有當(dāng)commit()的時候才一次性全部執(zhí)行所有內(nèi)存中的數(shù)據(jù)庫。

不用事務(wù)

如果不用事務(wù),插入1000條數(shù)據(jù)到sqlite數(shù)據(jù)庫,要執(zhí)行1000次開啟事務(wù)、結(jié)束事務(wù),大致意思如下圖:

這里寫圖片描述

使用事務(wù)

如果使用事務(wù),存儲1000條數(shù)據(jù)到sqlite數(shù)據(jù)庫,只需要執(zhí)行一次開啟事務(wù)、結(jié)束事務(wù)操作,大致意思如下圖:

這里寫圖片描述

時間成本應(yīng)該就是節(jié)約在多余的開啟事務(wù)和結(jié)束事務(wù)這里。

口說無憑,下面上截圖,大致存儲了6000條數(shù)據(jù),使用事務(wù)之前,需要花費7分鐘左右,下面是使用事務(wù)之后,僅僅用了2秒鐘:

這里寫圖片描述

Qt中使用事務(wù)的大致方法:

db.transaction();

執(zhí)行插入的sql(n條插入操作)

db.commit();

實例

下面是一段我寫的代碼,insert是我封裝的一個執(zhí)行sql語句的接口:

/添加數(shù)據(jù)到XXX表/bool DbManager::appendData2MfCali(const QList &data) {     if(data.isEmpty())         return false;     mDb->beginTransaction(); //開啟事務(wù)     foreach (MfCalibrate v, data)     {         QVector fieldValue;         fieldValue.append(QString::number(v.RfChannel));              fieldValue.append(QString::number(v.MfChannel));              fieldValue.append(QString::number(v.RfFreq));                fieldValue.append(QString::number(v.CollectValue));           fieldValue.append(QString::number(v.AmpCaliValue));           if(!mDb->insert("XXX表",mMfCaliFieldsName , fieldValue))             return false;     }     mDb->commitTransaction(); //提交     return true; }

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多