QT连接Mysql数据库,有驱动但是无法连接问题

在QT连接数据库时,遇见如图所示错误,在Qt的打印中具有QMYSQl驱动但是在加载时却提示显示没有。
首先看MySQL位数和QT编译器(构件套件)的位数要相同,如果相同那么将MySql数据库中如下图圈选内容添加入程序中即可。


代码如下:
QStringList drives = QSqlDatabase::drivers();
for each (QString str in drives)
{
std::cout << str.toStdString() << std::endl;
}
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) {
std::cout << "success" << std::endl;
}
结果:

在QT应用中尝试连接MySQL数据库时遇到驱动不可用的问题。尽管QMYSQl驱动已安装,但连接仍然失败。关键在于确保MySQL数据库和QT编译器的位数匹配,并正确配置数据库连接参数。通过遍历并打印可用驱动来检查QMYSQl驱动是否存在,然后设置数据库连接详细信息,包括主机名、端口、数据库名、用户名和密码。如果打开数据库失败,可能的原因是配置不正确或驱动问题。
1490

被折叠的 条评论
为什么被折叠?



