在网上找了一下关于如何在数据库中存储文件本体(一般是关于image)的内容,但是发现大多数的做法都是存储文件相应的路径,需要该文件的时候通过路径查询,感觉那样的做法的话,文件只是在一种抽象的方式被存储在了数据库中,本体并没有被存储,这样做可能是出于效率和数据库大小的考虑(本人对数据库知道的不多)。因为前段时间对QT比较感兴趣,然后发现其中可以使用第三方的数据库,于是尝试了下。
(1)创建数据库连接
bool MyDatabase::CreateConnection()
{
db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("mydb.db");
if (!db.open()) {
qDebug()<>>>>> 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