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;
}
结果: