溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Qt4.8.6編譯mysql驅(qū)動(dòng)-深入了解

發(fā)布時(shí)間:2020-06-05 13:33:09 來(lái)源:網(wǎng)絡(luò) 閱讀:1195 作者:哈夫猿 欄目:軟件技術(shù)

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)的解決方案。


   



向AI問一下細(xì)節(jié)

免責(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)容。

AI