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

php中文网
发布: 2016-06-01 13:01:13
原创
2084人浏览过

还记得之前的一个项目里要向数据库中存入图片,然后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:imageschuancaiaicai.jpg')的作用就是往image字段写入图片,这里用的是绝对路径,表示你图片所在的位子。这是在windows下,如果是在Linux下,要把目录间隔改成//。

Bertha.ai
Bertha.ai

一款专为WordPress打造的AI内容和图像创建工具

Bertha.ai 120
查看详情 Bertha.ai

这样我们就已经在数据库里写入了图片了。

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将图片写入数据库了。

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号