zoukankan      html  css  js  c++  java
  • 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,然后解压,写入到文件中。

     

    本例仅是示范,希望对大家能够有所帮助。

     

     

  • 相关阅读:
    python 默认编码( UnicodeDecodeError: 'ascii' codec can't decode)
    python发送各类邮件的主要方法
    python输出htmltestrunner中文乱码如何解决
    Python unittest 官方文档
    Python pip 安装包
    Python easy_insatll 安装包
    linux 解压操作命令
    vim 操作指令2
    vim 操作指令1
    (转)水波纹过渡特效
  • 原文地址:https://www.cnblogs.com/zelos/p/3402873.html
Copyright © 2011-2022 走看看