windows下QT5.9连接MYSQL

首先,按照教程尝试连接数据库:

QSqlDatabase db = QSqlDatabase:: addDatabase( "QMYSQL");
    db.setHostName("localhost");
    db.setPort(3306);
    db.setDatabaseName("test");
    db.setUserName("用户名");
    db.setPassword("密码");
    bool ok = db.open();
    if (!ok)
    {
    qDebug()<<"连接失败";
    }
    else
    {
    qDebug()<<"成功!";
    }

运行报错:
QSqlDatabase: QMYSQL driver not loaded

QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7

连接失败


意思大概就是:“QMYSQL驱动加载失败”,“可用驱动有:QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL7”。

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

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

windows下QT5.9连接MYSQL
将这三个文件复制到D:\QT5.9\5.9.2\mingw53_32\bin路径下,还是回报上边的错误,没办法只能手动加载库:

void loadSqlDriver()

{
    QPluginLoader loader;
    loader.setFileName("D:/QT5.9/5.9.2/mingw53_32/plugins/sqldrivers/qsqlmysqld.dll");
    qDebug() << loader.load();
}

打印true,再尝试连接数据库就显示连接成功了
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值