您的位置:首页 > 编程语言 > Qt开发

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

2014-06-26 19:43 489 查看
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,而后就是打开数据库了。
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;  


(2)创建存储说需要的表

查看是否存在相关的表,不存在,则通过"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,然后解压,写入到文件中。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: