在银河麒麟系统中Qt连接达梦数据库

解决在银河麒麟系统中使用Qt连接达梦数据库提示:project Error library odbc is not defined问题

一、编译ODBC

下载解压unixODBC(http://www.unixodbc.org/unixODBC-2.3.1.tar.gz)

打开终端,切换到unixODBC-2.3.1目录下,并输入:

./configure --prefix=/usr/local/unixODBC

在分别输入:

make

make install

在/usr/local/unixODBC/lib文件夹下生成如下文件,红框中的三个文件一个会用到

打开终端,切换到/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

注:如果出现红框中的两个问题,请查看二、三小节

在odbc文件夹下会产生Makefile文件

在终端中分别执行:

make

make install

在Qt安装目录下/home/watertk/Qt5.12.0/5.12.0/gcc_64/plugins/sqldrivers会产出两个文件

Qt中运行如下代码,可以看到有ODBC的驱动,并打开数据库成功

二、提示:ldrivers-config.pri: No such file or directory

在Qt安装目录,如下图所示的文件夹中,更改qsqldriverbase.pri文件中的代码

把qtsqldrivers-config.pri改成configure.pri,保存文件,重新编译

三、提示: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文件夹下

更改odbc.pro中的代码,保存文件,重新编译

#QMAKE_USE += odbc

QMAKE_LFLAGS += libodbc.so

相关推荐
誰能久伴不乏3 小时前
【Qt实战】工业级多线程串口通信:从底层协议设计到完美收发闭环
linux·c++·qt
liu****3 小时前
4.Qt窗口开发全解析:菜单栏、工具栏、状态栏及对话框实战
数据库·c++·qt·系统架构
从此不归路8 小时前
Qt5 进阶【11】图形视图框架:用 QGraphicsView 搭一个流程图编辑器
开发语言·c++·qt
凯子坚持 c9 小时前
Qt常用控件指南(7)
服务器·数据库·qt
wkd_00711 小时前
【Qt | QTableWidget】QTableWidget 类的详细解析与代码实践
开发语言·qt·qtablewidget·qt5.12.12·qt表格
残梦531412 小时前
Qt6.9.1起一个图片服务器(支持前端跨域请求,不支持上传,可扩展)
运维·服务器·开发语言·c++·qt
mengzhi啊12 小时前
QT的语言家使用方法示范
qt
Henry Zhu12312 小时前
Qt网络编程详解(下):项目实战
网络·qt
轩情吖13 小时前
Qt布局管理器
开发语言·c++·qt·布局管理器·桌面级·qvboxlayout·qhboxlayout
CSDN_RTKLIB13 小时前
Qt Creator中修改源文件编码
qt