您好,登錄后才能下訂單哦!
Qt4.8.6編譯mysql驅(qū)動(dòng)-深入了解
前些天的博文中講述了Window+qt+vc++2017編譯器這種組合下通過(guò)Qt標(biāo)準(zhǔn)庫(kù)SQL接口連接mysql數(shù)據(jù)庫(kù)情形,并成功解決了加載mysql驅(qū)動(dòng)失敗的問題。雖然有了點(diǎn)成績(jī)但是依舊沒有解決在Qt4.8.6+mingw這種組合下mysql數(shù)據(jù)庫(kù)連接的問題。
1、軟件環(huán)境
操作系統(tǒng):windows10(64位)
Qt版本:4.8.6(mingw版本)
編譯器:g++(4.8.2)
MySQL:5.7.22(64位、32位,)
g++ --version查詢到的信息如下:
g++.exe (i686-posix-dwarf-rev3, Built by MinGW-W64 project) 4.8.2
qmake -version查詢到信息如下:
QMake version 2.01a
Using Qt version 4.8.6 in C:\Qt\4.8.6\lib
2、歷史遺留問題
1、Qt4中默認(rèn)沒有mysql驅(qū)動(dòng),需要手動(dòng)編譯;
2、編譯mysql驅(qū)動(dòng)需要提取mysql服務(wù)端程序內(nèi)的include和lib,通過(guò)網(wǎng)絡(luò)搜索可發(fā)現(xiàn)大多數(shù)的解決方案都需要使用lib/opt這個(gè)目錄,但是mysql5.7中已經(jīng)沒有這個(gè)目錄。
3、編譯mysql驅(qū)動(dòng)是通過(guò)構(gòu)建%QTDIR%\src\plugins\sqldrivers\mysql\mysql.pro項(xiàng)目完成,編譯完成后正常情況下會(huì)生成調(diào)試版和發(fā)布版的.a文件和dll文件。
4、歷史處理方法是修改mysql.pro文件加入兩條記錄(include和lib已經(jīng)提取出來(lái)了):
INCLUDEPATH+="C:\driver2\include"
LIBS+="C:\driver2\lib\libmysql.lib"
5、通過(guò)上述處理,在構(gòu)建項(xiàng)目時(shí),Qt Creator中會(huì)報(bào)出大量“undefined reference to xxxxxx"錯(cuò)誤。至此,就無(wú)法繼續(xù)進(jìn)行下去。
6、百度N邊,解決方案都是在重復(fù)問題4,近乎陷入死循環(huán)()。
3、N天后.........
..........@($*&(#@*7.......
4、神來(lái)之筆
偶然之間清理mysql.pro的項(xiàng)目的垃圾文件 ,赫然在Debug目錄內(nèi)存在一個(gè)qsqlmysl4.a文件,但是沒有qsqlmysql4.dll這個(gè)文件,可以確認(rèn)編譯成功了一半,自己的配置有一部分是正確的。
重新構(gòu)建項(xiàng)目,自習(xí)查看編譯輸出的內(nèi)容,有一行打印“Makefile.Debug:77:recipe for target 'tdebug\qsqlmysql4.dll' failed”
果斷百度了一下這個(gè)問題,最終的解決方案參考了qt編譯mysql驅(qū)動(dòng)程序錯(cuò)誤的解決。問題根本原因是msyql安裝的為64位,而mingw版本為32位,導(dǎo)致libmysql.dll文件不匹配。
5、致謝
感謝各位大神貢獻(xiàn)的解決方案。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。