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

本文介绍如何在MySQL数据库中存储和从Qt应用程序中读取图片。首先创建包含longblob类型图片字段的表,使用LOAD_FILE函数插入图片。在Qt中,通过查询数据库获取图片的二进制数据,然后加载到QLabel中显示。同时,展示了通过Qt将图片写入数据库的方法,包括路径处理和使用QByteArray存储二进制数据。
摘要由CSDN通过智能技术生成

还记得之前的一个项目里要向数据库中存入图片,然后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将图片写入数据库了。

没什么技巧,希望可以帮到跟我一样需要的菜鸟,也期望有师兄指教错误或者是有更好的方法。

f68f2add0b68e4f9810432fce46917b7.png

相关标签:图片 数据库

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值