1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 将mysql数据库中的图片读出来的_MySQL存入图片+Qt读入读出数据库中的图片

将mysql数据库中的图片读出来的_MySQL存入图片+Qt读入读出数据库中的图片

时间:2024-01-22 04:21:08

相关推荐

将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为例:

QStringselect="select*fromsfood";

query.exec(select);

if( query.next())

{

QLabel*PicLabel=newQLabel();

QPixmapphoto;photo.loadFromData(query.value(5).toByteArray(),"JPG"); //从数据库中读出图片为二进制数据,图片格式为JPG,然后显示到QLabel里PicLabel->setPixmap(photo);PicLabel->setScaledContents(true);

}

3.通过Qt往数据库中写入图片

query.exec("select*fromsfoodwherename='"+nameEdit->text()+"'"); //我这里本段代码是添加菜品,该句是查询是否有该菜,按名字查询if(query.next()){QMessageBox::information(this,tr("警告"),tr("该菜已在数据库存储了"));db.Close();return;}query.prepare("insertintosfood(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("OpenFile"),"/home",tr("Images(*.jpg)"));*/QByteArraybytes;QBufferbuffer(&bytes);buffer.open(QIODevice::WriteOnly);pictureLabel->pixmap()->save(&buffer,"JPG");QByteArraydata;QFile*file=newQFile(imagePath);//file为二进制数据文件名file->open(QIODevice::ReadOnly);data=file->readAll();file->close();QVariantvar(data);query.addBindValue(var);query.exec();

ok,已经通过Qt将图片写入数据库了。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。