QT5打开图片并显示,然后保存到数据库中

本文介绍如何在QT5应用中打开图片,使用QLabel显示,并将图片保存到MYSQL数据库。首先安装MYSQL数据库,然后在mainwindow.cpp中实现相关函数,尽管遇到图片显示不全和数据保存后乱码的问题,但最终成功完成实验。
摘要由CSDN通过智能技术生成

目标:打开确定图片,使用QLabel控件显示在UI中,并将此图片保存在数据库中;在此,使用的是MYSQL数据库
1.安装MYSQL数据库,我参考的是这位UP主的博客,一模一样的操作方法
下载并安装以及简单调试MYSQL
在此,表示感谢!在众多的教程中我选中了这个并开始,然后一次性成功
2.接下来进入主题
mainwindow.cpp中,实现函数MainWindow:: createConnection()(记得在mainwindow.h中声明)

MainWindow:: createConnection()
{
    QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");//选择数据库
    db.setHostName("localhost");//进行连接
   // db.setPort(3306);端口可查看自己的
    db.setDatabaseName("upMySql");//选择数据库名称,这里是我选的数据库
    db.setUserName("root");
    db.setPassword("123456");//这里输入你自己的密码
    db.open();
    if(!db.open()) {
        qDebug()<<"Failed to connect to root mysql admin";
    }
    else {
        qDebug()<<"open success!";
    }
    /*至此,数据库连接成功*
  • 1
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Qt使用数据库可以通过Qt自带的Qt SQL模块来实现。下面是一个简单的示例代码,演示了如何使用SQLite数据库保存用户数据: 首先,确保已在项目文件(.pro)添加了对Qt SQL模块的引用: ```plaintext QT += sql ``` 然后,可以按照以下步骤使用数据库: 1. 引入必要的头文件: ```cpp #include <QSqlDatabase> #include <QSqlQuery> #include <QSqlError> ``` 2. 创建数据库连接并打开数据库: ```cpp QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("mydatabase.db"); // 指定数据库文件名 if (!db.open()) { qDebug() << "无法建立数据库连接!"; return; } ``` 3. 创建数据表(如果尚未存在): ```cpp QSqlQuery query; query.exec("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)"); if (query.lastError().isValid()) { qDebug() << "无法创建数据表!" << query.lastError(); return; } ``` 4. 插入用户数据到数据库: ```cpp QString name = "John"; int age = 30; query.prepare("INSERT INTO users (name, age) VALUES (:name, :age)"); query.bindValue(":name", name); query.bindValue(":age", age); if (!query.exec()) { qDebug() << "无法插入数据!" << query.lastError(); return; } ``` 5. 查询数据库的用户数据: ```cpp query.exec("SELECT * FROM users"); while (query.next()) { int id = query.value("id").toInt(); QString name = query.value("name").toString(); int age = query.value("age").toInt(); qDebug() << "ID:" << id << "Name:" << name << "Age:" << age; } ``` 6. 关闭数据库连接: ```cpp db.close(); ``` 以上代码示例了如何使用Qt SQL模块在SQLite数据库保存用户数据。你可以根据需要修改表结构、插入数据和查询数据的逻辑。同时,Qt SQL模块也支持其他类型的数据库,如MySQL、PostgreSQL等,只需更改数据库驱动和连接参数即可。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值