成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

解析QT 使用Sqlite存儲(chǔ)讀取文件

移動(dòng)開發(fā)
本文介紹的是QT 使用Sqlite存儲(chǔ)讀取文件,文件只是在一種抽象的方式被存儲(chǔ)在了數(shù)據(jù)庫(kù)中,本體并沒有被存儲(chǔ),詳細(xì)內(nèi)容請(qǐng)看本文內(nèi)容。

QT 使用Sqlite存儲(chǔ)讀取文件是本文所介紹的內(nèi)容,Qt中使用第三方的數(shù)據(jù)庫(kù)(Sqlite)存儲(chǔ)并讀取文件本體,在網(wǎng)上找了一下關(guān)于如何在數(shù)據(jù)庫(kù)中存儲(chǔ)文件本體(一般是關(guān)于image)的內(nèi)容,但是發(fā)現(xiàn)大多數(shù)的做法都是存儲(chǔ)文件相應(yīng)的路徑,需要該文件的時(shí)候通過路徑查詢,感覺那樣的做法的話,文件只是在一種抽象的方式被存儲(chǔ)在了數(shù)據(jù)庫(kù)中,本體并沒有被存儲(chǔ),這樣做可能是出于效率和數(shù)據(jù)庫(kù)大小的考慮(本人對(duì)數(shù)據(jù)庫(kù)知道的不多)。因?yàn)榍岸螘r(shí)間對(duì)QT比較感興趣,然后發(fā)現(xiàn)其中可以使用第三方的數(shù)據(jù)庫(kù),于是嘗試了下。

(1)創(chuàng)建數(shù)據(jù)庫(kù)連接

  1. bool MyDatabase::CreateConnection()  
  2. {  
  3. db = QSqlDatabase::addDatabase("QSQLITE");  
  4. db.setDatabaseName("mydb.db");  
  5. if (!db.open()) {  
  6. qDebug()<<" can't open database >>>>>> mydb.db";  
  7. exit(-1);  
  8. }  
  9. return true;  

使用第三方數(shù)據(jù)庫(kù)Sqlite,數(shù)據(jù)庫(kù)名字為mydb.db,而后就是打開數(shù)據(jù)庫(kù)了。

  1. bool MyDatabase::CreateTable()  
  2. {  
  3. QStringList tableList = db.tables();  
  4. QSqlQuery query(db);  
  5. if(!tableList.contains("files"))  
  6. {  
  7. QString createTable = "create table files (id integer primary key," 
  8. "filename varchar(128) unique, filecontent blob)";  
  9. if(!query.exec(createTable))  
  10. {  
  11. qDebug()<<query.lastError();  
  12. exit(-1);  
  13. }  
  14. }  
  15. return true;  

(2)創(chuàng)建存儲(chǔ)說需要的表

查看是否存在相關(guān)的表,不存在,則通過"create table files (id integer primary key,filename varchar(128) unique, filecontent blob)";創(chuàng)建files表。

(3)存儲(chǔ)文件名為

  1. bool MyDatabase::StoreFile(QString FileName)  
  2. {  
  3. QSqlQuery query(db);  
  4. QFile File(FileName);  
  5. if(File.open(QIODevice::ReadOnly)){  
  6. QByteArray &tdata = File.readAll();  
  7. QByteArray data = qCompress(tdata,9);  
  8. query.prepare("INSERT INTO files (id,filename,filecontent)"  
  9. "VALUES(NULL,:filename,:filecontent)");  
  10. query.bindValue(":filename", FileName);  
  11. query.bindValue(":filecontent", data);  
  12. if(!query.exec())  
  13. {  
  14. qDebug()<<query.lastError();  
  15. return false;  
  16. }  
  17. }  
  18. else  
  19. {  
  20. return false;  
  21. }  
  22. return true;  

基本思想就是把名為FileName的文件裝換成為QByteArray,然后使用第三方的zlib進(jìn)行最高等級(jí)的壓縮,然后存儲(chǔ)

(4)從數(shù)據(jù)庫(kù)中

  1. bool MyDatabase::GetFile(QString FileName)  
  2. {  
  3. QSqlQuery query(db);  
  4. query.prepare("select filecontent from files");  
  5. query.exec();  
  6. query.next();  
  7. QByteArray tdata = query.value(0).toByteArray();  
  8. QByteArray data = qUncompress(tdata);  
  9. QFile File(FileName);  
  10. if(File.open(QIODevice::WriteOnly))  
  11. {  
  12. File.write(data);  
  13. File.close();  
  14. }  
  15. else  
  16. {  
  17. return false;  
  18. }  
  19. return true;  

因?yàn)閮H僅是嘗試,所以只需讀取一個(gè)并把它命名為FileName。基本思想是把存儲(chǔ)在數(shù)據(jù)庫(kù)中的內(nèi)容轉(zhuǎn)化為QByteArray,然后解壓,寫入到文件中。

小結(jié):關(guān)于解析QT 使用Sqlite存儲(chǔ)讀取文件的內(nèi)容介紹完了,希望本文對(duì)你有所幫助!

責(zé)任編輯:zhaolei 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2011-06-20 14:18:27

Qt 資源 文件

2011-06-27 09:15:21

QT Creator

2013-05-03 13:42:20

iOS開發(fā)SQLite3存儲(chǔ)讀取

2011-07-05 14:46:34

2011-07-05 10:22:44

Qt Sqlite

2011-07-04 17:18:23

Qt SQLite 數(shù)據(jù)庫(kù)

2020-11-02 13:24:49

MySQL數(shù)據(jù)庫(kù)存儲(chǔ)

2011-06-14 10:18:58

QThread Qt 線程

2011-06-09 15:47:01

Qt Visual Stu

2011-06-30 16:53:18

QT Creator TableWidge

2011-06-15 09:02:01

Qt QDomDocume XML

2022-11-04 11:34:15

文件pathlibfileinput

2011-06-29 09:56:29

QT UI 動(dòng)態(tài)加載

2011-08-30 14:15:34

QTSQLite數(shù)據(jù)庫(kù)

2011-07-05 17:54:43

QT Sqlite ARM

2011-06-09 15:18:07

QT 編譯

2011-06-08 15:27:24

QT QT 4.5 編譯

2011-09-09 17:59:26

QT Widget

2011-07-01 15:04:49

Qt 內(nèi)省

2011-07-04 17:26:00

Qt SQLite
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 色噜噜狠狠色综合中国 | 久久久视| 久久精品一区二区视频 | 韩日一区| 青娱乐av | 日本一区二区高清不卡 | 毛片大全 | 天天天天天天操 | 亚洲av一级毛片 | 九九九视频在线观看 | av黄色片在线观看 | 国产女人第一次做爰毛片 | 免费在线性爱视频 | 久久免费国产 | 亚洲精品一区久久久久久 | 777zyz色资源站在线观看 | 精品一区二区久久久久久久网站 | 亚洲自拍一区在线观看 | 日韩中文字幕一区二区 | 亚洲激情网站 | 亚洲综合在线播放 | 国产视频一区二区在线观看 | 亚洲一区在线日韩在线深爱 | 日韩视频成人 | 亚洲一区二区综合 | 亚洲成人三区 | 欧美一区二区三区在线 | 在线婷婷| 国产精品久久久久久二区 | 久久艹av| 最新av中文字幕 | 一区二区三区在线电影 | 麻豆av片 | 天堂久久av| 欧美成人a| 日日爱夜夜操 | 精品无码久久久久久国产 | 久久久久久亚洲精品 | 成人黄色三级毛片 | 久久99视频| 国产日产欧产精品精品推荐蛮挑 |