Qt本机release版本能连接mysql,但是到其他机器上就报错driver not loaded

2025-03-06 19:55:11
推荐回答(2个)
回答1:

  1.安装qt的时候还没有安装mysql.也就是说应该在安装qt之前安装mysql数据库.这个错误由QSqlDatabase抛出db.lastError().text()
  2.将以前编译的mysql驱动程序拷入qt文件夹位置放错.
  3.你的程序写错了.
  4."driver not loaded" 是由query.lastError().text()抛出的错误.
  5.gcc版本不一样(本机和目标机).
  既然知道原因了,解决起来也就非常轻松了.
  1.重新安装qt,重新安装mysql驱动
  2和3的解决方法我就没有什么好说的了.
  4. 说明你的query在创建的时候没有和qsqldatabase建立起关联.正确的方法是声明qsqldatabase后就声明query.如果你希望一 个连接能够和多个query关联使用如下语法:QSqlQuery query(db),db是QSqlDatabase的实例名.
  5.同步gcc版本咯..
  首先,运行如下测试代码:
  //don't forget about QT+= sql
  qDebug() << QSqlDatabase::drivers();
  QSqlDatabase db( QSqlDatabase::addDatabase( "QMYSQL" ) );
  qDebug() << db.lastError();

回答2:

题主解决了吗 我也遇到同样的问题,网上说的方法都试过了并没有什么卵用