Qt中使用第三方的数据库(Sqlite)存储并读取文件本体
2008-12-31 15:09
507 查看
在网上找了一下关于如何在数据库中存储文件本体(一般是关于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,然后解压,写入到文件中。
本例仅是示范,希望对大家能够有所帮助。
(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,然后解压,写入到文件中。
本例仅是示范,希望对大家能够有所帮助。
相关文章推荐
- Qt中使用第三方的数据库(Sqlite)存储并读取文件本体
- 解析QT 使用Sqlite存储读取文件
- 解析QT 使用Sqlite存储读取文件
- 数据库操作_连接SQL Server数据库示例;连接ACCESS数据库;连接到 Oracle 数据库示例;SqlCommand 执行SQL命令示例;SqlDataReader 读取数据示例;使用DataAdapter填充数据到DataSet;使用DataTable存储数据库表;将数据库数据填充到 XML 文件;10 使用带输入参数的存储过程;11 使用带输入、输出参数的存储过程示;12 获得数据库中表的数目和名称;13 保存图片到SQL Server数据库示例;14 获得插入记录标识号;Exce
- 解决:Android使用自带sqlite开发时,apk中创建的数据库外部的进程是没有权限去读/写的,而且无法如何读取指定目录下的db文件
- 数据库SQLite 数据大量存储 和快速读取 链表查询的优化 使用gosn
- 使用Sqlite3存储和读取数据
- 使用hibernate读取txt文件导入数据库
- 使用SQLite3存储和读取数据
- 使用QT对access数据库进行操作——数据库中表、记录和域的读取
- Android游戏开发13:SQLite存储数据及保存SQLite数据库文件到SD卡
- 数据库SQLite在Qt5+VS2012使用规则总结---中文乱码
- [ios]如何使用 Xcode,读取和写入存在的数据库文件?
- C# 使用FileUpload控件上传图片,将文件转换成二进制进行存储与读取
- iOS开发24:使用SQLite3存储和读取数据
- 使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中
- Android 学习 应用使用大文件的方法 读取sd卡的数据库
- android学习记录3(数据存储的方式:sqlite、sp、存文件。listview简单使用)
- 使用SQLite3存储和读取数据
- 读取存储在MsSql下的文件,配合使用DataGrid的模板列。