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

前端之家收集整理的这篇文章主要介绍了解析QT 使用Sqlite存储读取文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

(1)创建数据库连接

 
 
  1. boolMyDatabase::CreateConnection()
  2. {
  3. db=QsqlDatabase::addDatabase("QsqlITE");
  4. db.setDatabaseName("mydb.db");
  5. if(!db.open()){
  6. qDebug()<<"can'topendatabase>>mydb.db";
  7. exit(-1);
  8. }
  9. returntrue;
  10. }

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

  
  
  • boolMyDatabase::CreateTable()
  • {
  • QStringListtableList=db.tables();
  • QsqlQueryquery(db);
  • if(!tableList.contains("files"))
  • {
  • QStringcreateTable="createtablefiles(idintegerprimarykey,"
  • "filenamevarchar(128)unique,filecontentblob)";
  • if(!query.exec(createTable))
  • {
  • qDebug()<query.lastError();
  • exit(-1);
  • }
  • }
  • returntrue;
  • }
  • (2)创建存储说需要的表

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

    (3)存储文件名为

      
      
  • boolMyDatabase::StoreFile(QStringFileName)
  • {
  • QsqlQueryquery(db);
  • QFileFile(FileName);
  • if(File.open(QIODevice::ReadOnly)){
  • QByteArray&tdata=File.readAll();
  • QByteArraydata=qCompress(tdata,9);
  • query.prepare("INSERTINTOfiles(id,filename,filecontent)"
  • "VALUES(NULL,:filename,:filecontent)");
  • query.bindValue(":filename",FileName);
  • query.bindValue(":filecontent",data);
  • if(!query.exec())
  • {
  • qDebug()query.lastError();
  • returnfalse;
  • }
  • }
  • else
  • {
  • returnfalse;
  • }
  • returntrue;
  • }
  • 基本思想就是把名为FileName的文件装换成为QByteArray,然后使用第三方的zlib进行最高等级的压缩,然后存储

    (4)从数据库

      
      
  • boolMyDatabase::GetFile(QStringFileName)
  • {
  • QsqlQueryquery(db);
  • query.prepare("selectfilecontentfromfiles");
  • query.exec();
  • query.next();
  • QByteArraytdata=query.value(0).toByteArray();
  • QByteArraydata=qUncompress(tdata);
  • QFileFile(FileName);
  • if(File.open(QIODevice::WriteOnly))
  • {
  • File.write(data);
  • File.close();
  • }
  • else
  • {
  • returnfalse;
  • }
  • returntrue;
  • }
  • 因为仅仅是尝试,所以只需读取一个并把它命名为FileName。基本思想是把存储在数据库中的内容转化为QByteArray,然后解压,写入到文件中。

    猜你在找的Sqlite相关文章