fedora 18~20 中Qt 5.2.1 解決連接mysql數據庫出現QMYSQL driver not loaded的問題


 

 在CODE上查看代碼片派生到我的代碼片
  1. QT       += sql //在.pro文件里加入這一句  
  2.   
  3. //包含頭文件  
  4. #include <QDebug>  
  5. #include <QSqlQuery>  
  6. #include <QSqlDatabase>  
  7.   
  8. //連接數據庫  
  9.     QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");  
  10.     db.setHostName("localhost");  
  11.     db.setDatabaseName("mydb");  
  12.     db.setUserName("root");  
  13.     db.setPassword("123456");  
  14.     bool ok = db.open();  
  15.     if(!ok)  
  16.     {  
  17.         qDebug()<<"open db fail";  
  18.         return;  
  19.     }  
  20.   
  21. //將數據表中的內容全部列出  
  22.     QSqlQuery query;  
  23.     query.exec("SELECT * FROM tb_A2");  
  24.     while(query.next())  
  25.     {  
  26.         qDebug()<<query.value(0).toString()<<query.value(1).toString();  
  27.     }  
如上,我編寫了一個簡單的測試數據庫連接的程序,運行時出現了下面的錯誤提示:

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QPSQL QPSQL7

在Qt5.2.1中明明已經有MySQL的驅動QMYSQL,為什么還是無法加載呢?

去google了一把,網上大多數是windows下和Qt4.x版本的,還好最終還是解決了,現在稍微記錄解決過程下。

//Qt的安裝路徑

#cd /opt/Qt5.2.1/5.2.1/gcc/plugins/sqldrivers/

#ls

libqsqlite.so  libqsqlmysql.so  libqsqlpsql.so

#ldd libqsqlmysql.so
這里就會發現:

libmysqlclient_r.so.16 =>not found

怎么解決呢?

//mysql 安裝庫路徑

#cd /usr/lib/mysql/

#ls

INFO_BIN              libmysqlclient.so.18          mysqlbug
INFO_SRC              libmysqlclient.so.18.0.0      mysql_config
libmysqlclient.so.18.0.0.bak  plugin

#cplibmysqlclient.so.18.0.0 libmysqlclient_r.so.16

#mvlibmysqlclient_r.so.16 /lib/

#cd /opt/Qt5.2.1/5.2.1/gcc/plugins/sqldrivers/

#ldd libqsqlmysql.so

看看libmysqlclient_r.so.16是否還是not found

如果出現

libmysqlclient_r.so.16 => /lib/libmysqlclient_r.so.16

則說明已經成功了。如果還不行,再試着創建一軟連接看看,

# pwd

/opt/Qt5.2.1/5.2.1/gcc/plugins/sqldrivers
#ln -s /lib/libmysqlclient_r.so.16 ./libmysqlclient_r.so.16

 

Good luck !


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM