最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 19:47:24
文档

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

MySQL存入图片+Qt读入读出数据库中的图片_MySQL:还记得之前的一个项目里要向数据库中存入图片,然后Qt要在数据库中读入读出图片,当时纠结了好久,查阅了很多资料才解决,所以希望本文能给需要朋友点帮助。好了废话不多说,下面开始讲实现步骤。 1.MySQL存入图片 首先建表时要声明字段的类型为longblo
推荐度:
导读MySQL存入图片+Qt读入读出数据库中的图片_MySQL:还记得之前的一个项目里要向数据库中存入图片,然后Qt要在数据库中读入读出图片,当时纠结了好久,查阅了很多资料才解决,所以希望本文能给需要朋友点帮助。好了废话不多说,下面开始讲实现步骤。 1.MySQL存入图片 首先建表时要声明字段的类型为longblo


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

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

文档

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

MySQL存入图片+Qt读入读出数据库中的图片_MySQL:还记得之前的一个项目里要向数据库中存入图片,然后Qt要在数据库中读入读出图片,当时纠结了好久,查阅了很多资料才解决,所以希望本文能给需要朋友点帮助。好了废话不多说,下面开始讲实现步骤。 1.MySQL存入图片 首先建表时要声明字段的类型为longblo
推荐度:
标签: 图片 数据库 读取
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top