詳解Qt 4.7編譯和訪問Mysql驅(qū)動(dòng)
Qt 4.7編譯和訪問Mysql驅(qū)動(dòng)是本文要介紹的內(nèi)容,不多說,我們來看內(nèi)容。今天摸索了一上午,終于用qt連上mysql 了
1、安裝一個(gè)mysql 5.0以上版本***<網(wǎng)上都說要非安裝版,其實(shí)不一定要非安裝版,注意以下兩點(diǎn)就好>
要求:(1)安裝路徑不要有空格和點(diǎn)
(2)不要默認(rèn)安裝,選自定義安裝,保證mysql的安裝目錄下有include文件夾<即安裝好C庫>
假設(shè)mysql安裝目錄為e:/qt/mysql/
3、安裝sdk版的qt即可,將E:\Qt\2010.05\mingw\bin和E:\Qt\2010.05\qt\bin添加進(jìn)path環(huán)境變量
假設(shè)qt目錄為E:/Qt/2010.05/
4、由于需要使用mingw來編譯mysql,所以需要下載mingw-utils-0.3.tar.gz編譯包
http://www.qtcn.org/download/mingw-utils-0.3.tar.gz
解壓這個(gè)包,將bin下的所有文件復(fù)制到Qt\2010.05\mingw\bin下
5、用cmd進(jìn)入%QTDIR%\src\plugins\sqldrivers\mysql
(1)執(zhí)行cmd命令:reimp -d E:/qt/mysql/lib/opt/libmysql.lib
生成LIBMYSQL.def文件
(2)執(zhí)行cmd命令:dlltool -k -d libmysql.def -l libmysql.a
將LIBMYSQL.def轉(zhuǎn)成了libmysql.a文件
(3)執(zhí)行cmd命令:qmake -o Makefile "INCLUDEPATH+=E:/qt/mysql/include""LIBS+=E:/qt/mysql/lib/opt/LIBMYSQL.a" mysql.pro
生成makefile,makefile.debug,makefile.release
注意:如果系統(tǒng)安裝有vc,那么打開以上三個(gè)文件夾,將有關(guān)vc的東西全部刪除,否則以下編譯出錯(cuò)
6、打開mysql.pro文件添加以下語句(注意反斜杠的寫法)
- INCLUDEPATH += E:/Qt/MySQL/include
- LIBS += E:/Qt/2010.05/qt/src/plugins/sqldrivers/mysql/libmysql.a
7、執(zhí)行cmd命令:ming32-make
8、完成mysql驅(qū)動(dòng)的編譯。
- E:\Qt\2010.05\qt\plugins\sqldrivers將生成以下兩個(gè)文件:
- qsqlmysql4.dll
- qsqlmysqld4.dll
這兩個(gè)文件則是mysql的驅(qū)動(dòng)庫了。
9、測試工程
.pro文件增加以下三行
- QT += sql *******這行必須加
- INCLUDEPATH += E:/Qt/MySQL/include ********這行不加可能也行
- LIBS += E:/Qt/2010.05/qt/src/plugins/sqldrivers/mysql/libmysql.a ********這行不加可能也行
.cpp文件<部分源碼>
- QSqlDatabase Connect=QSqlDatabase::addDatabase("QMYSQL");
- Connect.setDatabaseName("mydata");//注意數(shù)據(jù)庫名<需要自己在mysql下先建立,如何建立查資料啊>
- Connect.setHostName("127.0.0.1");//本地訪問
- Connect.setPort(3306);
- Connect.setUserName("root");//用戶名
- Connect.setPassword("12345");//注意密碼<需要提前在mysql下設(shè)置吧>
- if(Connect.open())
- {
- qDebug()<<"MySql right!!";
小結(jié):關(guān)于詳解Qt 4.7編譯 訪問Mysql驅(qū)動(dòng)的內(nèi)容介紹完了,希望本文對你有所幫助!更多內(nèi)容請參考編輯推薦。