解析QT 使用Sqlite存储读取文件

转载 2013年12月05日 11:05:09

QT 使用Sqlite存储读取文件是本文所介绍的内容,Qt中使用第三方的数据库(Sqlite)存储并读取文件本体,在网上找了一下关于如何在数据库中存储文件本体(一般是关于image)的内容,但是发现大多数的做法都是存储文件相应的路径,需要该文件的时候通过路径查询,感觉那样的做法的话,文件只是在一种抽象的方式被存储在了数据库中,本体并没有被存储,这样做可能是出于效率和数据库大小的考虑(本人对数据库知道的不多)。因为前段时间对QT比较感兴趣,然后发现其中可以使用第三方的数据库,于是尝试了下。

(1)创建数据库连接

  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;  

使用第三方数据库Sqlite,数据库名字为mydb.db,而后就是打开数据库了。

  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)创建存储说需要的表

查看是否存在相关的表,不存在,则通过"create table files (id integer primary key,filename varchar(128) unique, filecontent blob)";创建files表。

(3)存储文件名为

  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进行最高等级的压缩,然后存储

(4)从数据库中

  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;  

因为仅仅是尝试,所以只需读取一个并把它命名为FileName。基本思想是把存储在数据库中的内容转化为QByteArray,然后解压,写入到文件中。


相关文章推荐

QT sqlite3数据库读取、容器操作、文件读写——学习笔记。

直接上代码 #include "dbpoi.h" #include #include #include #include #include #include #include...
  • swqqcs
  • swqqcs
  • 2012-06-19 21:04
  • 8439

解析xml文件,并把解析结果存储到android的SQLite数据库

以下面xml文件为例对其解析(假设此xml就在服务器端Server项目下的servlet包下的MenuServlet文件的输出流中): - - 1 1 水煮鱼 ...

使用SQLite3存储和读取数据

SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。基本操作:(1)打开或者创建数据库sqlite3 *database; int ...

使用SQLite3存储和读取数据

SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。 基本操作: (1)打开或者创建数据库 sqlite3 *data...

使用SQLite3存储和读取数据

使用SQLite3存储和读取数据

使用SQLite3存储和读取数据

SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。 基本操作: (1)打开或者创建数据库 sqlite3 *data...

使用SQLite3存储和读取数据

SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。 基本操作: (1)打开或者创建数据库 sqlite3 *data...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)