qt编程使用sqlite存储读取文件
Qt中使用第三方的数据库(Sqlite)存储并读取文件本体 在网上找了一下关于如何在数据库中存储文件本体(一般是关于image)的内容,但是发现大多数的做法都是存储文件相应的路径,需要该文件的时候通过路径查询,感觉那样的做法的话,文件只是在一种抽象的方式被存储在了数据库中,本体并没有被存储,这样做可能是出于效率和数据库大小的考虑(本人对数据库知道的不多)。因为前段时间对QT比较感兴趣,然后发现其中可以使用第三方的数据库,于是尝试了下。 (1)创建数据库连接 bool MyDatabase::CreateConnection() { db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("mydb.db"); if (!db.open()) { qDebug()<<" can't open database >>>>>> mydb.db"; exit(-1); } return true; } 使用第三方数据库Sqlite,数据库名字为mydb.db,而后就是打开数据库了。 (2)创建存储说需要的表 bool MyDatabase::CreateTable() { QStringList tableList = db.tables(); QSqlQuery query(db); if(!tableList.contains("files")) { QString createTable = "create table files (id integer primary key," "filename varchar(128) unique,filecontent blob)"; if(!query.exec(createTable)) { qDebug()<<query.lastError(); exit(-1); } } return true; } 查看是否存在相关的表,不存在,则通过"create table files (id integer primary key,filename varchar(128) unique,filecontent blob)";创建files表。 (3)存储文件名为 bool MyDatabase::StoreFile(QString FileName) { QSqlQuery query(db); QFile File(FileName); if(File.open(QIODevice::ReadOnly)){ QByteArray &tdata = File.readAll(); QByteArray data = qCompress(tdata,9); query.prepare("INSERT INTO files (id,filename,filecontent)" "VALUES(NULL,:filename,:filecontent)"); query.bindValue(":filename",FileName); query.bindValue(":filecontent",data); if(!query.exec()) { qDebug()<<query.lastError(); return false; } } else { return false; } return true; } 基本思想就是把名为FileName的文件装换成为QByteArray,然后使用第三方的zlib进行最高等级的压缩,然后存储 (4)从数据库中 bool MyDatabase::GetFile(QString FileName) { QSqlQuery query(db); query.prepare("select filecontent from files"); query.exec(); query.next(); QByteArray tdata = query.value(0).toByteArray(); QByteArray data = qUncompress(tdata); QFile File(FileName); if(File.open(QIODevice::WriteOnly)) { File.write(data); File.close(); } else { return false; } return true; } 因为仅仅是尝试,所以只需读取一个并把它命名为FileName。基本思想是把存储在数据库中的内容转化为QByteArray,然后解压,写入到文件中。 本例仅是示范,希望对大家能够有所帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- ruby-on-rails – Rails 3.0移动网站
- 什么时候是C终止处理程序Right Thing(TM)?
- npm install在node_modules中清除react-native
- ios – IBDesignables无法在Xcode中呈现
- ruby-on-rails – 如何在hostgator上部署Ruby on Rails应用
- c# – 从第三方应用程序调用类库时出现MissingMethodExcept
- oracle——distinct的用法
- Nand flash driver
- dwr3.0与Spring mvc的全注解集成方法( @RemoteMethod)(@Rem
- c# – 如何获取Asp.NET中的url响应值