IT码农库

您当前所在位置:首页 > 数据库 > Mysql

Mysql

QT连接Mysql数据库的具体教程(亲测成功版)

[db:来源] 程序有序2023-05-11Mysql2164
被Qt连接数据库折磨了三天之后终于连接成功了,记录一下希望对观到的人有所帮助,下面这篇文章主要给大家介绍了关于QT连接Mysql数据库的具体教程,文中通过图文介绍的非常具体,需要的朋友可以参考下

前言

QT连接Mysql数据库步骤相对比较麻烦,因此写了篇文章将具体过程呈现给大家。

方法一、直接通过MySQL的驱动加载数据库

示例代码:

(1)在.pro文件中添加下列代码:

QT +=sql

(2)在mainwindow.h文件中添加下列头文件:

#include<QSqlDatabase>

 (3)在main.cpp文件中添加下列代码:

QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("127.0.0.1");  //连接本地主机
    db.setPort(3306);
    db.setDatabaseName("数据库名");
    db.setUserName("用户名");
    db.setPassword("密码");
    bool ok = db.open();
    if (ok){
        QMessageBox::information(this, "infor", "link success");
    }
    else {
        QMessageBox::information(this, "infor", "link failed");
        qDebug()<<"error open database because"<<db.lastError().text();
    }
 

运行代码,假如连接Mysql成功则输出下面结果:

假如连接Mysql失败则输出:

 假如连接Mysql失败也不用太灰心,方法一在初次连接时很多情况下都会出错。下面我们来观观第二种成功率更高的连接方法。

方法二、通过ODBC连接MySQL数据库

1.下载地址

ODBC下载官网

(1)选择适合自己QT版本的ODBC版本。

详细如何查观自己QT是多少位的,可以通过QT软件上方的菜单栏  帮助->About QT Creator 查观位数

(2)点击DownLoad后会入进下面的界面

 点击No thanks,just start my download即可下载,不用点击上面的登录按钮,否则会有繁琐的登录步骤。

(3)下载完ODBC后,双击安装,一直点next即可完成安装。

(4)安装之后在电脑左下角的搜索栏中输进ODBC即可查观安装后的ODBC

(5)点击添加按钮添加用户DSN.

(6)点击MYSQL ODBC 8。0 ANSI Driver。

(7)这里的内容按照下面提示对应填好即可。

(8)完成Mysql的添加后,可以点击Test按钮测试一下能否连接。

2.ODBC连接代码

代码如下:

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
    db.setHostName("127.0.0.1");
    db.setPort(3306);
    db.setDatabaseName("刚刚在ODBC中创建的Data source name"); //不是Database,记得别填错
    db.setUserName("用户名");
    db.setPassword("密码");
    bool ok = db.open();
    if (ok){
        QMessageBox::information(this, "infor", "link success");
    }
    else {
        QMessageBox::information(this, "infor", "link failed");
        qDebug()<<"error open database because"<<db.lastError().text();
    }

恭喜你走到这一步,离成功连接Mysql只差最后一步!运行代码,一般都是可以完成连接的了。

总结

QT连接Mysql数据库的步骤相对繁琐,但是也是一个不错的学习经历。

到此这篇关于QT连接Mysql数据库的文章就介绍到这了,更多相关QT连接Mysql数据库内容请搜索以前的文章或继承浏览下面的相关文章希望大家以后多多支持!

大图广告(830*140)