Qt5.5连接Mysql数据库(数据库版本为5.5)

因为以前总是用Qt连接Oracle数据库,这次是因为新的软件系统需要使用Mysql,我的Mysql的版本是5.5,本来以为一切顺利,Qt已经带有连接Mysql的动态库文件:

这里写图片描述

Qt的程序代码为:

#include <QtCore/QCoreApplication>
#include <QSqlDatabase>
#include <QDebug>
#include <QSqlQuery>
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");  
    db.setHostName("192.168.8.130");
    db.setDatabaseName("test");
    db.setUserName("root");
    db.setPort(3306);
    db.setPassword("admin");
    if (db.open())
    {
        qDebug()<<"suceess Connect!";
    }
    else
    {
        qDebug()<<"error Connect!";
    }
    return a.exec();
}

但是运行结果却无法连接数据库,出现如下的错误:

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7

其报错的原因是Mysql连接缺少驱动,但是明明可用驱动中包含QMYSQL,为什么会提示加载失败呢?查看了一坨资料,总结了一下,应该是缺了加载mysql驱动时所需要的一些东西,导致加载失败。

根据网上提供的方法:将mysql安装目录中的libmysql.dll文件拷贝到QT安装目录下的bin目录中就可以了:
Mysql其状目录下:

这里写图片描述

复制到qt的bin目录下:

这里写图片描述

但是运行程序后仍然发现出现一模一样的错误,仔细查看原因,还是不太清楚,隐约感觉是Mysql的驱动的问题,重新去官网下载新的驱动:下载32位的zip压缩包
然后复制到Qt的bin目录下面,运行上面的程序:

这里写图片描述

至此,Qt连接Mysql数据库Success,但是某些具体的原因不太清楚,如果有人知道原因,可以在下面留言,不胜感激。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值