Qt连接MySQL出现QSqlDatabase: QMYSQL driver not loaded

本文介绍了解决QSqlDatabase提示QMYSQL driver未加载的问题方法。首先确认系统已安装libqsqlmysql.so,若未安装可通过yum安装qt-mysql。安装后需确保Qt能正确找到该库文件,可通过调整Qt的库搜索路径或复制库文件到Qt搜索路径内来实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

QSqlDatabase: QMYSQL driver not loaded

QSqlDatabase: available drivers: QSQLITE

解决方法,先看下是否已经安装了libqsqlmysql.so

[test1@localhost ~]$ locate libqsqlmysql.so

/var/cache/abrt-di/usr/lib/debug/usr/lib/qt4/plugins/sqldrivers/libqsqlmysql.so.debug

我的系统上还没有安装,下面安装 qt-mysql.i686。

[root@localhost test1]# yum install qt-mysql.i686

================================================================================

 Package           Arch          Version                 Repository        Size

================================================================================

Installing:

 qt-mysql          i686          1:4.7.4-7.fc14          updates           67 k

[root@localhost test1]# updatedb

[test1@localhost ~]$ locate libqsqlmysql.so

/usr/lib/qt4/plugins/sqldrivers/libqsqlmysql.so

/var/cache/abrt-di/usr/lib/debug/usr/lib/qt4/plugins/sqldrivers/libqsqlmysql.so.debug

在程序里面调用

qDebug()<<QCoreApplication::libraryPaths ();

可以看到Qt 搜索库的路径。里面并没有/usr/lib/qt4/plugins/

这里有两种方式解决这个问题:

1、把libqsqlmysql.so所在的路径增加到库路径里面:

     QcoreApplication::addLibraryPath("/usr/lib/qt4/plugins/");

2、直接复制libqsqlmysql.so到Qt的搜索路径中。

[test1@localhost ~]$ cp /usr/lib/qt4/plugins/sqldrivers/libqsqlmysql.so QtSDK/Desktop/Qt/4.8.1/gcc/plugins/sqldrivers/    



http://doc.qt.nokia.com/4.7-snapshot/sql-driver.html

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值