QT C++ 读写mySQL数据库 图片 例子

在上篇文章中描述了怎样搭建读写数据库的环境。

本文更进一步,描述了读写mySQL数据库,字符、整型数字、图片。读写图片相对难点。

数据库的图片字段用BLOB,如果图片较大要用longblob,否则会报错。

另外,读写数据库都使用了短连接,完成后关闭连接

本文代码在QT6.2.4 MSVC2019 +MySQL5.7.44_X64 调试通过。

//1.数据库字段

              图1-数据库字段示意图

//2.界面

图2-界面

//3.代码

//3.1 头文件

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QPushButton>
#include <QLabel>
#include <QVBoxLayout>
#include <QtSql/qtsql>

QT_BEGIN_NAMESPACE
namespace Ui {
class Widget;
}
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();
    void initUI();//初始化界面
    QPushButton* btn_write ;//写入按钮
    QPushButton* btn_read;//读取按钮
    QLabel * lb_name;//显示姓名
    QLabel * lb_age;//显示年龄
    QLabel * lb_picture;//显示图片

  

private:
    Ui::Widget *ui;
    QByteArray m_imageData2;//图片的字节数组
    QString m_name;//姓名变量
    int m_age;//年龄变量

private slots:
    void btn_write_click();//写入按钮子程序
    void btn_read_click();//读取按钮子程序

};
#endif // WIDGET_H

//-----------------------------------------------------------------------------------------------------------

//3.2  cpp文件

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    initUI();
}
void Widget::initUI()
{
     QVBoxLayout* vlayout = new QVBoxLayout();
     btn_write = new QPushButton(this);
     btn_write->setText("写入数据库");
     btn_write->setFixedWidth(100);
     vlayout->addWidget(btn_write);
     btn_read = new QPushButton(this);
     btn_read->setText("读数据库");
     btn_read->setFixedWidth(100);
     vlayout->addWidget(btn_read);
     lb_name=new QLabel("待读出姓名");
     lb_name->setFixedWidth(100);
     vlayout->addWidget(lb_name);
     lb_age=new QLabel("待读出年龄");
     lb_age->setFixedWidth(100);
     vlayout->addWidget(lb_age);
     lb_picture=new QLabel("待读出图片");
      vlayout->addWidget(lb_picture);
     setLayout(vlayout);
    QObject::connect(btn_write, &QPushButton::clicked,this,&Widget::btn_write_click);
    QObject::connect(btn_read, &QPushButton::clicked,this,&Widget::btn_read_click);
}
void Widget::btn_write_click()
{
    qDebug()<<QSqlDatabase::drivers();
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("127.0.0.1");
    db.setPort(3306);
    db.setDatabaseName("db_name");//你自己的数据库名称
    db.setUserName("root");
    db.setPassword("123456");

    if (!db.open()) {
        qDebug()<<"不能连接"<<"connect to mysql error"<<db.lastError().text();
        return ;
    }
    else
    {
        qDebug()<<"数据库连接成功";
    }

   
    QString imagePath = "d:/Pictures/LeiJun.png";
    // Read image file
    QFile file(imagePath);
    if (!file.open(QIODevice::ReadOnly)) {
        qDebug() << "Error: Failed to open image file";
        return  ;
    }
    QByteArray imageData = file.readAll();

    QSqlQuery query;
    query.prepare("INSERT INTO test (name, age,image) VALUES (:value1, :value2, :value3)");
    query.bindValue(":value1", "LeiJun");
    query.bindValue(":value2", 50);
    query.bindValue(":value3", imageData);

    if (!query.exec())

    {
        qDebug() << "Failed to insert data. Error: " << query.lastError().text();
        db.close();
        return  ;
    }
    qDebug() << "Data inserted successfully";
    db.close();
}
void Widget::btn_read_click()
{
    qDebug()<<QSqlDatabase::drivers();
    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("127.0.0.1");
    db.setPort(3306);
    db.setDatabaseName("db_name");//你自己的数据库名称
    db.setUserName("root");
    db.setPassword("123456");

    if (!db.open()) {
        qDebug()<<"不能连接"<<"connect to mysql error"<<db.lastError().text();
         db.close();
        return ;
    }
    else
    {
        qDebug()<<"数据库连接成功";
    }
   
     //读图片
     QSqlQuery query;
      query.exec("SELECT * FROM test WHERE name = 'LeiJun' LIMIT 1;");
    if (!query.next()) {
        qDebug() << "Error: Failed" << query.lastError().text();
         db.close();
        return ;
    }
    else
        qDebug() << "读数据成功";

    //姓名
    m_name = query.value(0).toString();
    qDebug()<<m_name;
    lb_name->setText(m_name);
    //年龄
    m_age = query.value(1).toInt();
    qDebug()<<m_age;
    lb_age->setText(QString::number(m_age));
    //图片的二进制
    m_imageData2 = query.value(2).toByteArray();//转换成字节数组
    // Create image from data
    QPixmap pixmap;
    pixmap.loadFromData(m_imageData2);
     lb_picture->setPixmap(pixmap);显示图片

    db.close();
}
Widget::~Widget()
{
    delete ui;
}

//4.代码下载链接

https://download.csdn.net/download/weixin_39926429/89374527

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/19062.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pytorch 星号*放在tensor前的作用

假如有一个多维tensor&#xff0c;名为id&#xff0c;那么*id的意思是什么呢&#xff1f; GPT答&#xff1a; 如果 id 是一个多维张量&#xff0c;那么 *id 在这种情况下会将这个多维张量解包成一个张量序列&#xff0c;其中每个元素都是一个更低维度的张量。具体来说&#x…

图形学初识--空间变换

文章目录 前言正文矩阵和向量相乘二维变换1、缩放2、旋转3、平移4、齐次坐标下总结 三维变换1、缩放2、平移3、旋转绕X轴旋转&#xff1a;绕Z轴旋转&#xff1a;绕Y轴旋转&#xff1a; 结尾&#xff1a;喜欢的小伙伴可以点点关注赞哦 前言 前面章节补充了一下基本的线性代数中…

前端Vue小兔鲜儿电商项目实战Day02

一、Pinia快速入门 此处见&#xff1a;Vue从入门到实战Day12-CSDN博客 二、创建项目并精细化配置 1. 创建项目 2. src目录调整 ①删除一些初始化的默认文件 清空assets、components、store、views文件夹下的内容&#xff1b; ②修改剩余代码内容 router/index.js import …

一个程序员的牢狱生涯(44)询问

星期一 询 问 在号子里开始了下午坐班的时候,过道内的大铁栅栏被管教打开,我听到开锁的声音后,心里变得激动起来。盼望着脚步声能停在我们的号子门口,然后打开铁门,喊一声“眼镜,出来!”。 通道内这次进来的是秦所,但他并没有在我们号子门口停留,只是在走过的时候,低…

华为昇腾310 ATC模型转换工具安装

参考: https://bbs.huaweicloud.com/blogs/393282?utm_source=zhihu&utm_medium=bbs-ex&utm_campaign=other&utm_content=content https://www.hiascend.com/document/detail/zh/canncommercial/601/inferapplicationdev/atctool/atctool_0004.html 1、基本工具…

js知识点之闭包

闭包 什么是闭包 闭包&#xff0c;是 JavaScript 中一个非常重要的知识点&#xff0c;也是我们前端面试中较高几率被问到的知识点之一。 打开《JavaScript 高级程序设计》和《 JavaScript 权威指南》&#xff0c;会发现里面针对闭包的解释各执一词&#xff0c;在网络上搜索关…

Java中如何指定jdk的版本运行jar包

你的jdk安装的目录\bin\java -jar 你的jar包名字.jar 这是我的代码示例 C:\Users\86177\.jdks\corretto-17.0.10\bin\java -jar big_event_study2-0.0.1- SNAPSHOT.jar

23种设计模式之一— — — —装饰模式详细介绍与讲解

装饰模式详细讲解 一、定义二、装饰模式结构核心思想模式角色模式的UML类图应用场景模式优点模式缺点 实例演示图示代码演示运行结果 一、定义 装饰模式&#xff08;别名&#xff1a;包装器&#xff09; 装饰模式&#xff08;Decorator Pattern&#xff09;是结构型的设计模式…

LeetCode 每日一题 数学篇 2651.计算列车到站时间

给你一个正整数 arrivalTime 表示列车正点到站的时间&#xff08;单位&#xff1a;小时&#xff09;&#xff0c;另给你一个正整数 delayedTime 表示列车延误的小时数。 返回列车实际到站的时间。 注意&#xff0c;该问题中的时间采用 24 小时制。 int findDelayedArrivalTi…

学业辅导导师:文心一言智能体详细介绍和开发

一、前言 本期题目 开发方向&#xff1a;学习成长类 解读&#xff1a; AI技术在学习成长方向的应用正日益增多&#xff0c;本期赛题需围绕该方向开发智能体包括但不限于:作文辅导助手、个性化学习助手、考试助手、各垂类教育内容专家等 二、我的智能体&#xff1a;学业辅导…

macbook中foxmail的通讯录迁移

之前windows中用习惯了foxmail,换成macbook后,还是沿用foxmail。使用一段时间后,确实受不了foxmail的不便:1、版本比较低1.5.6,很多windows新版的功能都没有;2、动不动莫名其妙崩溃,写了半天的邮件,点击发送就直接崩了,又得重新写。 忍耐了几个月后,下定决心换成网易…

2.10 mysql设置远程访问权限

2.10 mysql设置远程访问权限 目录1. 管理员运行mysql命令窗口2. 使用 root 用户重新登录 MySQL3. 修改用户权限4. 修改mysql安装目录下的my.ini 目录 说明&#xff1a; Mysql8.0 设置远程访问权限 一、Mysql8.0 设置远程访问权限 1. 管理员运行mysql命令窗口 2. 使用 root 用…

matlab安装及破解

一、如何下载 软件下载链接&#xff0c;密码&#xff1a;98ai 本来我想自己生成一个永久百度网盘链接的&#xff0c;但是&#xff1a; 等不住了&#xff0c;所以大家就用上面的链接吧。 二、下载花絮 百度网盘下载速度比上载速度还慢&#xff0c;我给充了个会员&#xff0c…

【1】:计算机图形学概述

从技术角度讲&#xff0c;什么是好的画面呢&#xff1f; 看这个画面是不是足够亮&#xff0c;也就是全局光照做的够好 什么是计算机图形学? 使用计算机合成和操作可视信息。 应用场景 Video Games 游戏 Movie 电影 Animation 动画 Design 设计&#xff1a;CAD等软件相关…

修复CentOS 6.6服务器YUM和RPM功能异常的技术实践20240523

修复CentOS 6.6服务器YUM和RPM功能异常的技术实践 引言 在复杂的生产环境中&#xff0c;服务器的稳定性至关重要。近期&#xff0c;我们遇到了一台CentOS 6.6服务器在执行yum update -y时被中断&#xff0c;导致YUM和RPM功能异常的问题。本文将详细介绍问题的诊断、解决过程以及…

java中变量名单独占用一个空间吗,为什么能直接使用变量名而不需要给java地址,变量名和地址之间有什么关系

在 Java 中&#xff0c;变量名不单独占用存储空间&#xff0c;但它们确实在内存中有对应的地址。为了理解这一点&#xff0c;我们需要深入了解变量名和内存地址之间的关系。 变量名与内存地址 变量名的作用: 在 Java 程序中&#xff0c;变量名是用于引用存储在内存中的数据的…

git显示提交次数

git shortlog 是一个特殊版本的 git log 命令&#xff0c;旨在创建发布公告。它将每个提交按作者分组&#xff0c;并显示每个提交消息的第一行。这是一种快速查看不同作者在项目中的贡献的方式。 以下是 git shortlog 的一些常用参数&#xff1a; -n 或 --numbered&#xff1…

Java多线程——Lambda表达式

λ希腊字母表中排序第十一位的字母&#xff0c;英语名称为Lambda&#xff1b; 避免匿名内部类定义过多&#xff1b; 其实质属于函数式编程的概念。 为什么要用Lambda表达式&#xff1f; 1. 避免匿名内部类定义过多&#xff1b; 2. 可以让你的代码看起来更简洁&#xff1b; …

OpenAI 文生图模型演进:DDPM、IDDPM、ADM、GLIDE、DALL-E 2、DALL-E 3

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学。 针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 合集&#x…

WPF使用Prism实现简单订餐系统

新建wpf项目&#xff0c;nuget引入Prism.DryIoc&#xff0c;MaterialDesignThemes 引入后&#xff0c;修改App.xaml 前台引入 xmlns:prism"http://prismlibrary.com/"和prism:PrismApplication App.xaml.cs App.xaml.cs继承PrismApplication&#xff0c;重写CreateS…