Qt中编译mysql驱动程序及解决 driver not loaded 错误

来源:互联网 发布:网易蜂巢注册域名 编辑:程序博客网 时间:2024/05/16 08:57

前一段时间又需要编译Qt的MySQL驱动,不过这次顺利的多,因为有过编译的经验,而且还找到了一篇步骤全面的文章,在此Mark一下以便以后需要。



一、开发环境:

 操作系统:windows XP

 Qt版本: 4.5

 Qt安装目录:D:\devProgram\Qt

 mysql版本: 4.1

 mysql安装目录:D:\mysql41\lib\opt。(安装时选择了全部组件)

 

二、编译mysql驱动程序的过程:

1、用mingw-utils包中的reimp命令生成 libmysql.a 文件。

   注:mingw-utils 下载地址:http://www.qtcn.org/download/mingw-utils-0.3.tar.gz

   下载后解压缩,reimp命令在bin目录里。

   成生过程:

   1)、进入mysql安装目录: cd D:\mysql41\lib\opt

   2)、运行 reimp命令: reimp -d libmysql.lib

   3)、运行dlltool命令:dlltool -k -d libmysql.def -l libmysql.a

2、编译mysql驱动:

  1)、进入 qt 插件中的sqlsrivers目录:

        cd D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql

  2)、运行qmake命令:

        qmake -o Makefile "INCLUDEPATH+=D:\mysql41\include" "LIBS+=D:\mysql41\lib\opt\libmysql.a" mysql.pro

  3)、运行mingw32包里的 mingw32-make命令。(注不是make命令,也不是nmake命令。)

     注:如果mingw32-make命令运行出错,请把mingw32\bin加到path 环境变量中。

  4)、将生成的libqsqlmysqld4.a,qsqlmysqld4.dll 两个文件拷贝到 D:\devProgram\Qt\2009.03\qt\plugins\sqldrivers 目录下。

 

三、编写了一个简单的SQL程序:

int main(int argc, char *argv[])

{

QApplication a(argc, argv);

 

 

QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");

db.setDatabaseName("test");

db.setUserName("root");

db.setPassword("root");

bool ok = db.open();

std::cout << "db.open(): " << db.open() << std::endl;

}

   运行时提示:

   QSqlDatabase: QMYSQL driver not loaded
   QSqlDatabase: available drivers: QSQLITE QODBC3 QODBC

 

   说明mysql的驱动没有加载上。

四、解决办法:

  将mysql的dll文件所在的目录加到环境变量PATH中:

  Path= ...;D:\mysql41\lib\opt;

重新运行程序,提示:

 db.open(): 1

说明数据库已经连上。

 

参考links:

http://www.qtcn.org/bbs/read.php?tid=4210

http://linux.chinaunix.net/techdoc/database/2008/08/19/1026089.shtml

http://kenby.javaeye.com/blog/422708

 

 

操作日志:

Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.


D:\mysql41>cd D:\mysql41\lib\opt

D:\mysql41\lib\opt>D:\devProgram\Qt\mingw-utils-0.3\bin\reimp -d libmysql.lib

D:\mysql41\lib\opt>D:\devProgram\Qt\2009.03\mingw\bin\dlltool -k -d libmysql.def -l libmysql.a

D:\mysql41\lib\opt>cd D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql

D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql>qmake -o Makefile "INCLUDEPATH+=D:\mysql41\include" "LIBS+=D:\mysql41\lib\opt\libmysql.a" mysql.pro

D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql>nmake

Microsoft (R) Program Maintenance Utility   Version 6.00.8168.0
Copyright (C) Microsoft Corp 1988-1998. All rights reserved.

        NMAKE -f Makefile.Debug

Microsoft (R) Program Maintenance Utility   Version 6.00.8168.0
Copyright (C) Microsoft Corp 1988-1998. All rights reserved.

        g++ -c -g -frtti -fexceptions -mthreads -Wall -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LI
B -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\includ
e\ActiveQt" -I"debug" -I"..\..\..\..\mkspecs\default" -o debug\main.o main.cpp
'g++' 不是内部或外部命令,也不是可运行的程序
或批处理文件。
NMAKE : fatal error U1077: 'g++' : return code '0x1'
Stop.
NMAKE : fatal error U1077: '"D:\Microsoft Visual Studio\VC98\bin\NMAKE.EXE"' : return code '0x2'
Stop.

D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql>mingw32-make.exe
mingw32-make.exe -f Makefile.Debug
mingw32-make.exe[1]: Entering directory `D:/devProgram/Qt/2009.03/qt/src/plugins/sqldrivers/mysql'
g++ -c -g -frtti -fexceptions -mthreads -Wall -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LIB -DQT_C
ORE_LIB -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\include\Active
Qt" -I"debug" -I"..\..\..\..\mkspecs\default" -o debug\main.o main.cpp
D:/devProgram/Qt/2009.03/qt/bin\moc.exe -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LIB -DQT_CORE_LI
B -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\include\ActiveQt" -I
"debug" -I"..\..\..\..\mkspecs\default" -D__GNUC__ -DWIN32 ..\..\..\sql\drivers\mysql\qsql_mysql.cpp -o debug\qsql_mysql.moc
g++ -c -g -frtti -fexceptions -mthreads -Wall -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LIB -DQT_C
ORE_LIB -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\include\Active
Qt" -I"debug" -I"..\..\..\..\mkspecs\default" -o debug\qsql_mysql.o ..\..\..\sql\drivers\mysql\qsql_mysql.cpp
In file included from ..\..\..\sql\drivers\mysql\qsql_mysql.cpp:1476:
debug/qsql_mysql.moc:72:26: warning: no newline at end of file
D:/devProgram/Qt/2009.03/qt/bin\moc.exe -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LIB -DQT_CORE_LI
B -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\include\ActiveQt" -I
"debug" -I"..\..\..\..\mkspecs\default" -D__GNUC__ -DWIN32 ..\..\..\sql\drivers\mysql\qsql_mysql.h -o debug\moc_qsql_mysql.cpp
g++ -c -g -frtti -fexceptions -mthreads -Wall -DUNICODE -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_TO_ASCII -DQT_NO_CAST_FROM_ASCII -DQT_DLL -DQT_PLUGIN -DQT_SQL_LIB -DQT_C
ORE_LIB -DQT_THREAD_SUPPORT -I"..\..\..\..\include\QtCore" -I"..\..\..\..\include\QtSql" -I"..\..\..\..\include" -I"d:\mysql41\include" -I"..\..\..\..\include\Active
Qt" -I"debug" -I"..\..\..\..\mkspecs\default" -o debug\moc_qsql_mysql.o debug\moc_qsql_mysql.cpp
windres -i qsqlmysqld_resource.rc -o debug\qsqlmysqld_resource_res.o --include-dir=.
g++ -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-reloc -mthreads -Wl -shared -Wl,--out-implib,debug\libqsqlmysqld4.a -o debug\qsqlmysqld4
.dll debug/main.o debug/qsql_mysql.o debug/moc_qsql_mysql.o  -L"d:\devProgram\Qt\2009.03\qt\lib" debug\qsqlmysqld_resource_res.o D:\mysql41\lib\opt\libmysql.a -lQtSq
ld4 -lQtCored4
Creating library file: debug\libqsqlmysqld4.a
mingw32-make.exe[1]: Leaving directory `D:/devProgram/Qt/2009.03/qt/src/plugins/sqldrivers/mysql'

D:\devProgram\Qt\2009.03\qt\src\plugins\sqldrivers\mysql>


0 0
原创粉丝点击