解决在银河麒麟系统中使用Qt连接达梦数据库提示:project Error library odbc is not defined问题
一、编译ODBC
下载解压unixODBC(http://www.unixodbc.org/unixODBC-2.3.1.tar.gz)
data:image/s3,"s3://crabby-images/b7aed/b7aed4e4098633dfe391e34a67bbcf3541042456" alt=""
打开终端,切换到unixODBC-2.3.1目录下,并输入:
./configure --prefix=/usr/local/unixODBC
data:image/s3,"s3://crabby-images/79b94/79b941bf814d0e8a94c4f8e72f045d5aedab8729" alt=""
在分别输入:
make
make install
在/usr/local/unixODBC/lib文件夹下生成如下文件,红框中的三个文件一个会用到
data:image/s3,"s3://crabby-images/28f3c/28f3c68632b2139ae4a293427b293bee6a966380" alt=""
打开终端,切换到/home/watertk/Qt5.12.0/5.12.0/Src/qtbase/src/plugins/sqldrivers/odbc(注:/home/watertk/Qt5.12.0是Qt安装目录)
在终端中输入:
/home/watertk/Qt5.12.0/5.12.0/gcc_64/bin/qmake -makefile "INCLUDEPATH+=/usr/local/unixODBC/include" "LIBS+=-L/usr/local/unixODBC/lib -lodbc" odbc.pro
data:image/s3,"s3://crabby-images/49c05/49c055c7e4953df6df942be1159dc126405d7026" alt=""
注:如果出现红框中的两个问题,请查看二、三小节
在odbc文件夹下会产生Makefile文件
data:image/s3,"s3://crabby-images/54056/540561cda569679a0a9ddeaf6e6919c945e7ad85" alt=""
在终端中分别执行:
make
make install
在Qt安装目录下/home/watertk/Qt5.12.0/5.12.0/gcc_64/plugins/sqldrivers会产出两个文件
data:image/s3,"s3://crabby-images/b9a14/b9a143b21d8911411b22876259ce9a0a7655df7d" alt=""
Qt中运行如下代码,可以看到有ODBC的驱动,并打开数据库成功
data:image/s3,"s3://crabby-images/26ea1/26ea15b855014cbe8bb3bc730473d6742e3b3a1a" alt=""
二、提示:ldrivers-config.pri: No such file or directory
在Qt安装目录,如下图所示的文件夹中,更改qsqldriverbase.pri文件中的代码
data:image/s3,"s3://crabby-images/5c973/5c973d58398976cc8f7b7de24e994b0b3f49ee59" alt=""
把qtsqldrivers-config.pri改成configure.pri,保存文件,重新编译
data:image/s3,"s3://crabby-images/654ae/654aea734194d305e3713ebba2bde2238bf68a79" alt=""
三、提示:Project ERROR: Library 'odbc' is not defined.
把/usr/local/unixODBC/lib文件夹中的三个文件拷贝到
/home/watertk/Qt5.12.0/5.12.0/Src/qtbase/src/plugins/sqldrivers/odbc文件夹下
data:image/s3,"s3://crabby-images/198ed/198edf59164649699f3f3664a3dc14f2c6eb8193" alt=""
更改odbc.pro中的代码,保存文件,重新编译
#QMAKE_USE += odbc
QMAKE_LFLAGS += libodbc.so
data:image/s3,"s3://crabby-images/ae9e9/ae9e932a5c513d396c579a040bba357aaa6d3220" alt=""