Qt实现Mysql数据库的连接,查询,修改,删除,增加功能

news2024/10/7 14:27:56

Qt实现Mysql数据库的连接,查询,修改,删除,增加功能

  • 安装Mysql数据库,QtCreator

Mysql选择Mysql Server 8.1版本安装。

Mysql Server 8.1安装过程

1.首先添加网络服务权限:

Win+R键输入compmgmt.msc进入,计算机管理-系统工具-本地用户和组-组-Administrator

点击添加,在输入对象名称来选择栏,输入NETWORK SERVICE,点击检查名称,确认完成后退出。

  1. 下载Mysql8.1安装包,安装mysql。

Mysql8.1安装包下载地址:

https://download.csdn.net/download/qq_32663053/89163322

另外Mysql5.7.23版本的安装包下载地址:

https://download.csdn.net/download/qq_32663053/89163442

安装过程如下:

运行安装包:

选择安装类型:

选择安装产品:

执行安装:

安装完成,进行下一步:

Execute

执行下一步:

一直next的直到输入密码:

继续next到最后Mysql安装完毕。

配置环境变量:右击“我的电脑”–>“属性”–>“高级系统设置”–>“高级”–>“环境变量”,在打开的窗口中选择 “系统变量” 下的 “新建” 按钮创建环境变量。

尝试数据库关闭和开启:

“Windows+R”–>输入“cmd”–>Enter

到此Mysql数据库配置完成。

附带有Mysql Workbench,能够图形化处理数据库的功能软件。

  1. 下载QtCreator并加载Mysql驱动

QtCreator下载:由于QtCreator安装包过多,这里不提供。

安装过程:

安装过程选择source文件夹,否则无法配置mysql驱动。以下是我选的选项:

以后直接next直到安装结束。

  • 加载Mysql驱动
  1. 打开mysql.pro文件夹编译并生成mysql驱动文件

Mysql.pro文件位置如下(是本人的),不同的人不同位置。

用QtCreator打开mysql.pro文件配置mysql.pro文件。

圈出来的是要编写的代码,第一个注释掉mysql,第二个是将mysql的include文件和lib文件引入进来DESTDIR代表的是生成的驱动文件。代码写完执行锤子操作。执行结束后生成lib文件,也就是数据库驱动文件。

将数据库驱动文件复制到sqldriver文件夹下:我的目录如下:

将mysql文件夹下的libmysql.dll和libmysql.lib文件复制到qt的bin目录,以下是需要转移的目录

这样我们就可以连接mysql数据库了。

  • Qt连接Mysql数据库

编写代码如下连接Mysql数据库

  1. 首先在工程.pro文件下添加执行sql语句的代码:
  1. 定义一个全局变量QSqlDatabase db;用来打开数据库和操作数据库的变量。

如果连接成功则输出“数据库连接成功!”否则输出“数据库连接失败”+错误原因。

  • 数据库的查询操作

结果图:点击显示数据按钮,实现数据库表数据的显示。

QSqlQuery query=this->queryDatabase("select * from user");

//将数据库的查询结果集赋值给query

QSqlQueryModel *model=new QSqlQueryModel(ui->tableView);

//定义一个querymode绑定ui->tableView

    model->setQuery(query);//将查询结果绑定到模型上

    ui->tableView->setModel(model);

   //设置ui->tableView的mode。

这是显示数据的界面。

  • 数据库的删除操作

数据库的删除代码如下:

QString username = ui->lineEdit_3->text();

//从lineedit获得删除的主键数据进行预删除

    QSqlQuery query;

    //QString username=ui->lineEdit->text();

    //QSqlQuery query;

QString str=QString("delete from user where username='%1'").arg(username);

//编写删除sql语句

    if (!query.exec(str)) {    //执行删除语句

        qDebug() << "删除失败:" << query.lastError().text();

    } else {

        qDebug() << "删除成功";

    }

结果图如下:

  • 数据库的增加操作

数据库的增加数据是在另一个界面实现的,我们需要添加一个ui如下:

这样我们在dialog.cpp实现数据库的增加数据

QString username=ui->lineEdit->text();

QString password=ui->lineEdit_2->text();

//从lineedit读入要插入的数据

    QSqlQuery query;

    query.prepare("insert into sys.user values(?,?)");

    query.addBindValue(username);

query.addBindValue(password);

//预执行sql语句,并在语句中插入列数据

    if(!query.exec()){//执行增加数据语句

        qDebug()<<"无法插入数据";

        QMessageBox::information(NULL"增加表数据","增加失败",QMessageBox::Yes | QMessageBox::NoQMessageBox::Yes);

    }else{

        QMessageBox::information(NULL"增加表数据","增加成功",QMessageBox::Yes | QMessageBox::NoQMessageBox::Yes);

        Dialog::close();

    }

//如果增加失败,停留在子界面

//如果增加成功,返回主界面

//点击返回主界面按钮可以返回

实现的结果图:

  • 数据库的更新操作

更新操作,仍需要在子界面实现,子界面创建如六中的操作,操作是一样的。

首先是连接数据库然后输入主键的数值,找到所有列的信息:

db1=QSqlDatabase::addDatabase("QMYSQL");

    QString host="localhost";

    QString dbName="sys";

    QString user="root";

    QString password="12345";

this->connectToDatabase(host,dbName,user,password);

//以上是连接数据库

QString username = ui->lineEdit_3->text();

//获得主键信息

QSqlQuery query=this->queryDatabase(QString("select * from user where username = '%1'").arg(username));

//执行查询操作

    while (query.next()) {

        QString result = query.value(0).toString();

        QString result1 = query.value(1).toString();

        ui->lineEdit->setText(result);

        ui->lineEdit_2->setText(result1);

        ui->lineEdit->setReadOnly(true);

//将查询到的信息输出到lineedit中。

        qDebug() << result<<"   "<<result1;

}

然后我们修改非主键的列值。进行接下来的更新操作。

QString username = ui->lineEdit_3->text();

QString password = ui->lineEdit_2->text();

//获取所有列的数据,准备增加表数据

    QSqlQuery query;

   QString str=QString("update user set password = ? where username = ?");

//编写sql语句

    query.prepare(str);

    query.addBindValue(password);

query.addBindValue(username);

//预执行sql语句,并为未知量赋值

    if (!query.exec()) {//执行更新语句

        qDebug() << "更新失败:" << query.lastError().text();

        QMessageBox::information(NULL"更新表数据","更新失败",QMessageBox::Yes | QMessageBox::NoQMessageBox::Yes);

    } else {

        qDebug() << "更新成功";

        QMessageBox::information(NULL"更新表数据","更新成功",QMessageBox::Yes | QMessageBox::NoQMessageBox::Yes);

        Dialog1::close();

        //db1.close();

    }

//若成功,提示更新成功,并返回主界面

//若失败,停留在子界面。

实现的结果图:

以上就是QtCreator对Mysql数据库的增加、修改、删除、查询的操作。

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

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

相关文章

论文阅读:BEVBert: Multimodal Map Pre-training for Language-guided Navigation

BEVBert&#xff1a;语言引导导航的多模态地图预训练 摘要 现存的问题&#xff1a;目前大多数现有的预训练方法都采用离散的全景图来学习视觉-文本关联。这要求模型隐式关联全景图中不完整、重复的观察结果&#xff0c;这可能会损害智能体的空间理解。 本文解决方案&#xf…

PCBA镀金工艺介绍

PCBA&#xff08;印制电路板组装&#xff09;的镀金工艺是一种常见的表面处理方法&#xff0c;用于提高印制电路板&#xff08;PCB&#xff09;的性能和耐用性。本文将详细介绍PCBA的镀金工艺&#xff0c;包括其类型、工艺流程、优点及应用。 1. 镀金工艺的类型 PCBA的镀金主要…

Mac电脑版鼠标连点工具 RapidClick for Mac

RapidClick for Mac是一款方便实用的自动点击工具&#xff0c;可以帮助Mac用户在使用电脑时轻松、快速地进行鼠标操作。它可以模拟人类手指点击的动作&#xff0c;让您的鼠标点击变得更加快捷高效&#xff0c;大大提升了工作和游戏的效率。 RapidClick for Macv1.5.1激活版下载…

【windows-搭建Ubuntu22LTS】

一、环境要求 1. windows版本要求 至少Windows 10 2020年5月(2004) 版, Windows 10 2019年5月(1903) 版&#xff0c;或者 Windows 10 2019年11月(1909) 版 2. 控制面板开启相关的程序(需要重启) 二、Microsoft store安装unbuntu 下载后直接运行&#xff08;稍微等会&#…

mac: docker安装及其Command not found: docker

已经安装了docker desktop&#xff0c;没安装的 点击安装 傻瓜式安装即可 接着打开终端&#xff1a;好一个 Comand not found:docker 看我不把你整顿&#xff0c;解决如下&#xff1a; 如果你在 macOS 上安装了 Docker Desktop&#xff0c;但是终端无法识别 docker 命令&…

【ARM 裸机】汇编 led 驱动之烧写 bin 文件

1、烧写概念 bin 文件烧写到哪里呢&#xff1f;使用 STM32 的时候烧写到内部 FLASH&#xff0c;6ULL 没有内部 FLASH&#xff0c;是不是就不能烧写呢&#xff1f;不&#xff0c;6ULL 支持 SD卡、EMMC、NAND FLASH、NOR FLASH 等方式启动&#xff0c;在裸机学习的工程中&#x…

C++算法题 - 区间

目录 228. 汇总区间56. 合并区间57. 插入区间452. 用最少数量的箭引爆气球 228. 汇总区间 LeetCode_link 给定一个 无重复元素 的 有序 整数数组 nums 。 返回 恰好覆盖数组中所有数字 的 最小有序 区间范围列表 。也就是说&#xff0c;nums 的每个元素都恰好被某个区间范围所…

IDEA报错然后pycharm闪退

pycharm闪退&#xff0c;在C盘的USER文件夹下有报错文件 打开一看&#xff0c;说内存不足 # There is insufficient memory for the Java Runtime Environment to continue. # Native memory allocation (mmap) failed to map 14596177920 bytes for G1 virtual space # Possib…

Redis入门到通关之分布式锁Rediision

文章目录 ☃️setnx实现的分布式锁存的问题☃️Redisson☃️分布式锁-Redission快速入门☃️实战☃️总结 ☃️setnx实现的分布式锁存的问题 基于setnx实现的分布式锁存在下面的问题&#xff1a; 重入问题&#xff1a;重入问题是指 获得锁的线程可以再次进入到相同的锁的代码…

Win10系统下关闭管理员运行确认弹窗

Windows10及以上系统对于安全的考虑&#xff0c;对于程序运行时的权限做了控制 点击后&#xff0c;会弹出确认的弹窗。 像我做测试&#xff0c;或者使用cmd经常需要administrator 权限&#xff0c;一直弹弹弹就很烦。 要实现右击后无需弹窗就可以使用管理员权限运行改…

世强硬创获Jowat授权代理,其热熔胶可实现重新分离和循环使用

随着全球对环境保护意识的提升&#xff0c;政府机构对挥发性有机化合物&#xff08;VOCs&#xff09;和其他有害排放物的限制越来越严格&#xff0c;这促使粘合剂制造厂商开发更环保的产品。 为拓展中国市场&#xff0c;德国胶王股份有限公司&#xff08;下称“德国胶王”&…

FX110网:香港交易所宣布开发Orion衍生品平台,预计于 2028 年推出

香港交易及结算所有限公司&#xff08;香港交易所&#xff0c;HKEX&#xff09;今天宣布开发 Orion 衍生品平台&#xff08;ODP&#xff09;&#xff0c;提供增强的交易、清算和风险管理能力。 这个新平台由香港交易所技术团队自行开发&#xff0c;预计于 2028 年推出&#xff…

LeetCode题目42:接雨水【python 42/1000】

作者介绍&#xff1a;10年大厂数据\经营分析经验&#xff0c;现任大厂数据部门负责人。 会一些的技术&#xff1a;数据分析、算法、SQL、大数据相关、python 欢迎加入社区&#xff1a;码上找工作 作者专栏每日更新&#xff1a; LeetCode解锁1000题: 打怪升级之旅 python数据分析…

[C++][算法基础]求约数(试除法)

给定 n 个正整数 &#xff0c;对于每个整数 &#xff0c;请你按照从小到大的顺序输出它的所有约数。 输入格式 第一行包含整数 n。 接下来 n 行&#xff0c;每行包含一个整数 。 输出格式 输出共 n 行&#xff0c;其中第 i 行输出第 i 个整数 的所有约数。 数据范围 1≤…

直播预告:拥抱AI-探索AI大模型在邮件反钓鱼检测的应用

随着ChatGPT的问世&#xff0c;生成式AI技术迅速渗透到我们生活的各个角落&#xff0c;以ChatGPT为代表的生成式AI技术&#xff0c;依托其强大的AI模型和海量数据&#xff0c;赢得了广泛的欢迎。 然而&#xff0c;生成式AI的不断演进也带来了新的挑战。大型语言模型&#xff08…

单链表-通讯录

目录 单链表实现 通讯录代码实现 初始化 初始化函数 添加 删除 展示 查找 修改 销毁 代码展示 main.c text.c text.h list.c list.h 和前面的通讯录实现差不多这次就是实现一个以单链表为底层的通讯录 单链表实现 数据结构&#xff1a;单链表-CSDN博客 通讯…

【资源分享】SPSS 26免费下载安装

::: block-1 “时问桫椤”是一个致力于为本科生到研究生教育阶段提供帮助的不太正式的公众号。我们旨在在大家感到困惑、痛苦或面临困难时伸出援手。通过总结广大研究生的经验&#xff0c;帮助大家尽早适应研究生生活&#xff0c;尽快了解科研的本质。祝一切顺利&#xff01;—…

(51单片机)第十一章-串行口应用提高

11.1 方式0应用 在第6章中&#xff0c;已经对51单片机的串行口结构做过详细介绍&#xff0c;并且通过实例讲解了串行口的4种工作方式中方式1的具体用法&#xff0c;本节详细讲述串行口方式0的用法。 串行口方式0被称为同步移位寄存器的输入/输出方式&#xff0c;主要用于扩展并…

量化系统QTYX使用攻略|“选股框架”篇——组合对比分析,孰优孰劣一目了然(更新2.8.2)...

2024龙年大吉&#xff01;整装待发&#xff01;知识星球《玩转股票量化交易》精华内容概览 搭建自己的量化系统 股票量化交易系统QTYX是一个即可以用于学习&#xff0c;也可以用于实战炒股分析的系统。 分享QTYX系统目的是提供给大家一个搭建量化系统的模版&#xff0c;最终帮助…

OCP Java17 SE Developers 复习题13

答案 D, F. There is no such class within the Java API called ParallelStream, so options A and E are incorrect. The method defined in the Stream class to create a parallel stream from an existing stream is parallel(); therefore, option F is correct, and o…