Qt4.8.6編譯mysql驅動-深入瞭解

Qt4.8.6編譯mysql驅動-深入瞭解

        前些天的博文中講述了Window+qt+vc++2017編譯器這種組合下通過Qt標準庫SQL接口連接mysql數據庫情形,併成功解決了加載mysql驅動失敗的問題。雖然有了點成績但是依舊沒有解決在Qt4.8.6+mingw這種組合下mysql數據庫連接的問題。

1、軟件環境

    操作系統: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中默認沒有mysql驅動,需要手動編譯;

        2、編譯mysql驅動需要提取mysql服務端程序內的include和lib,通過網絡搜索可發現大多數的解決方案都需要使用lib/opt這個目錄,但是mysql5.7中已經沒有這個目錄。

        3、編譯mysql驅動是通過構建%QTDIR%\src\plugins\sqldrivers\mysql\mysql.pro項目完成,編譯完成後正常情況下會生成調試版和發佈版的.a文件和dll文件。

        4、歷史處理方法是修改mysql.pro文件加入兩條記錄(include和lib已經提取出來了):

            INCLUDEPATH+="C:\driver2\include"

            LIBS+="C:\driver2\lib\libmysql.lib"

        5、通過上述處理,在構建項目時,Qt Creator中會報出大量“undefined reference to xxxxxx"錯誤。至此,就無法繼續進行下去。

        6、百度N邊,解決方案都是在重複問題4,近乎陷入死循環()。

3、N天后.........

        ..........@($*&(#@*7.......

4、神來之筆

        偶然之間清理mysql.pro的項目的垃圾文件 ,赫然在Debug目錄內存在一個qsqlmysl4.a文件,但是沒有qsqlmysql4.dll這個文件,可以確認編譯成功了一半,自己的配置有一部分是正確的。

重新構建項目,自習查看編譯輸出的內容,有一行打印“Makefile.Debug:77:recipe for target 'tdebug\qsqlmysql4.dll' failed”

        果斷百度了一下這個問題,最終的解決方案參考了qt編譯mysql驅動程序錯誤的解決。問題根本原因是msyql安裝的爲64位,而mingw版本爲32位,導致libmysql.dll文件不匹配。

5、致謝

     感謝各位大神貢獻的解決方案。


   



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章