1. 程式人生 > >【轉載】MySQL存入圖片+Qt讀入讀出數據庫中的圖片

【轉載】MySQL存入圖片+Qt讀入讀出數據庫中的圖片

alt 頻道 AI ati post OS 讀取圖片 val info

/* Time: 2017.01.02 —— 2017.01.04

* Author: WJ

* Function:連接數據庫,從數據庫中讀取圖片並顯示(已成功)

*/

【參考鏈接】

MySQL存入圖片+Qt讀入讀出數據庫中的圖片 - lpdpzc的專欄 - 博客頻道 - CSDN.NET http://blog.csdn.net/lpdpzc/article/details/41915835

【主要代碼】

void MainWindow::on_ShowImage_clicked()

{

QSqlDatabase db ;

// 連接數據庫

if(QSqlDatabase::contains("qt_sql_default_connection"))

db = QSqlDatabase::database("qt_sql_default_connection");

else

{

db = QSqlDatabase::addDatabase("QMYSQL");

db.setHostName("localhost");

db.setDatabaseName("sfood");

db.setUserName("root");

db.setPassword("123456");

}

if(! db.open())

{

qDebug()<<"Fail to Opened!";

}

else

{

qDebug()<<"DataBase Opened!";

//建立查詢

QSqlQuery query;

query.exec("SELECT * FROM sfood"); //查詢未成功

if (! query.exec("SELECT * FROM sfood"))

{

qDebug()<<" Fail to Selecte !";

}

else

{

qDebug()<<" Selected Success!";

QPixmap photo;

qDebug()<<"顯示圖片";

if(query.first())

{

photo.loadFromData(query.value(5).toByteArray(), "JPG"); //從數據庫中讀出圖片為二進制數據,圖片格式為JPG,然後顯示到QLabel裏

}

ui->label->setPixmap(photo);

ui->label->setScaledContents(true);

}

}

}

【結果】

技術分享圖片技術分享圖片

【轉載】MySQL存入圖片+Qt讀入讀出數據庫中的圖片