程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL存入圖片+Qt讀入讀出數據庫中的圖片

MySQL存入圖片+Qt讀入讀出數據庫中的圖片

編輯:MySQL綜合教程

MySQL存入圖片+Qt讀入讀出數據庫中的圖片


還記得之前的一個項目裡要向數據庫中存入圖片,然後Qt要在數據庫中讀入讀出圖片,當時糾結了好久,查閱了很多資料才解決,所以希望本文能給需要朋友點幫助。好了廢話不多說,下面開始講實現步驟。

1.MySQL存入圖片

首先建表時要聲明字段的類型為longblob類型,如下:

create table `sfood`(
`name` varchar(255) not null,
`type` varchar(255) not null,
`material` varchar(255) not null,
`price` int(200) not null,
`feature` varchar(255) not null,
`image` longblob,
primary key(`name`)
)ENGINE=innodb default charset=gb2312;

image就是我的圖片字段,聲明為longblob類型,表示食物的圖片。

然後往表中插入數據:

insert into sfood(name,type,material,price,feature,image) values('生水白菜','川菜','白菜,生水',8,'清淡',LOAD_FILE('G:\\images\\chuancai\\baicai.jpg'));

這裡LOAD_FILE('G:\\images\\chuancai\\baicai.jpg')的作用就是往image字段寫入圖片,這裡用的是絕對路徑,表示你圖片所在的位子。這是在windows下,如果是在Linux下,要把目錄間隔改成//。

這樣我們就已經在數據庫裡寫入了圖片了。

2.在Qt裡如何把圖片從數據庫裡面讀出來,接下來的代碼都是以上面的表sfood為例:

 

QString select = "select * from sfood";
query.exec(select);
if( query.next() )
{
	QLabel *PicLabel = new QLabel();

QPixmap photo;
    photo.loadFromData(query.value(5).toByteArray(), "JPG"); //從數據庫中讀出圖片為二進制數據,圖片格式為JPG,然後顯示到QLabel裡
    PicLabel->setPixmap(photo);
    PicLabel->setScaledContents(true);
}

3.通過Qt往數據庫中寫入圖片


query.exec("select * from sfood where name='"+nameEdit->text()+"'"); //我這裡本段代碼是添加菜品,該句是查詢是否有該菜,按名字查詢
    if(query.next())
    {
        QMessageBox::information(this,tr("警告"),tr("該菜已在數據庫存儲了"));
        db.Close();
        return;
    }
    query.prepare("insert into sfood(name,type,material,price,feature,image) values(?,?,?,?,?,?)");
    query.addBindValue(nameEdit->text());
    query.addBindValue(typeEdit->text());
    query.addBindValue(materialEdit->toPlainText());
    query.addBindValue(priceEdit->text());
    query.addBindValue(featureEdit->text());

    //接下來代碼是保存圖片到數據庫
    imagePath.replace("\\","/");  //轉換路徑格式,imagePath是圖片文件的路徑,我這裡用的是絕對路徑
    /*imagePath的獲得方法可以這樣寫:
imagePath = QFileDialog::getOpenFileName(this, tr("Open File"),
                                                           "/home",
                                                          tr("Images (*.jpg)"));
    */
    
    QByteArray bytes;
    QBuffer buffer(&bytes);
    buffer.open(QIODevice::WriteOnly);
    pictureLabel->pixmap()->save(&buffer,"JPG");
    
    
    QByteArray data;
    QFile* file=new QFile(imagePath); //file為二進制數據文件名

    file->open(QIODevice::ReadOnly);
    data = file->readAll();
    file->close();
    QVariant var(data);
    query.addBindValue(var);

    query.exec();

ok,已經通過Qt將圖片寫入數據庫了。

沒什麼技巧,希望可以幫到跟我一樣需要的菜鳥,也期望有師兄指教錯誤或者是有更好的方法。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved