麒麟-QT-ODBC-达梦

bash 复制代码
xrandr
xrandr -s 1680x1050

1.搭建QT开发环境

下载并图形化安装qt

bash 复制代码
1.安装QT
chmod a+x qt-opensource-linux-x64-5.12.12.run
yum install libxkbcommon-x11
yum install gcc gcc-c++ make glibc-devel libstdc++-devel mesa-libGL mesa-libGL-devel
./qt-opensource-linux-x64-5.12.12.run


2.修改环境变量
vim ~/.bashrc

export QTDIR=/opt/Qt5.12.12/5.12.12/gcc_64  # Qt 主程序路径
export PATH=$QTDIR/bin:$PATH
export QT_PLUGIN_PATH=/opt/Qt5.12.12/5.12.12/gcc_64/plugins/sqldrivers/  # Qt 插件路径(如数据库驱动)
export MANPATH=$QTDIR/man:$MANPATH
export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH


export ODBCDM_HOME=/usr/local/unixODBC   # ODBC
export PATH=$ODBCDM_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ODBCDM_HOME/lib:$LD_LIBRARY_PATH

export DMHOME=/home/dmdba/dmdbms        #DM 这部分添加上 root才能访问。否则只能dmdba访问
export LD_LIBRARY_PATH=$DMHOME/bin:$LD_LIBRARY_PATH

source ~/.bashrc
 
验证
qmake -v

2.QT访问达梦

2.1Linux 环境创建 ODBC 数据源

C/C++ | 达梦技术文档

bash 复制代码
tar -zxvf libqsqlodbc.so.tar.gz -C  /root/下载/QODBC/
unzip libqsqlodbc.zip -d /root/下载/QODBC/
把libqslodbc.so 复制到 qt 目录下的 sqldrivers 目录下
bash 复制代码
1.ODBC安装
1.1下载文件 并解压
tar -zxvf unixODBC-2.3.12.tar.gz -C /home/ODBC

1.2.编译安装
cd unixODBC-2.3.12
 ./configure --prefix=/usr/local/unixODBC --sysconfdir=/etc  # 配置unixODBC的安装路径为/usr/local/unixODBC
 make 
 make install

1.3 验证ODBC是否安装成功?
odbc_config --version
odbcinst -j


2.让环境认识ODBC 配置环境变量 
vim ~/.bashrc 
export ODBCDM_HOME=/usr/local/unixODBC
export PATH=$ODBCDM_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ODBCDM_HOME/lib:$LD_LIBRARY_PATH
source ~/.bashrc 



3.ODBC配置DM数据库驱动。
 3.1 /etc/odbcinst.ini
[DM8 ODBC DRIVER]
Description     = ODBC DRIVER FOR DM8
Driver          =  /home/dmdba/dmdbms/bin/libdodbc.so


3.2 /etc/odbc.ini
[dm8]
Description = DM ODBC DSN
Driver = DM8 ODBC DRIVER
SERVER = 192.168.9.91
UID = SYSDBA
PWD = Int@4001093999
TCP_PORT = 5236

3.3 验证:用安装数据库的用户名 
su - dmdba
isql  dm8

2.2QT代码

cpp 复制代码
#include <QCoreApplication>
#include <QtSql>
#include <QDebug>
#include <QSqlDatabase>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

   qDebug()<<QSqlDatabase::drivers();

    QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
   db.setHostName("192.168.9.91");
        db.setPort(5236);
        db.setDatabaseName("dm8");
        db.setUserName("SYSDBA");
        db.setPassword("Int@4001093999");
    if (db.open())
        qDebug() << "connect ok!";
    else
    {
        qDebug() << "connect fail! " << db.lastError().text().toLatin1();
    }

    return a.exec();
}
相关推荐
暮云星影13 分钟前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
东风破13717 分钟前
达梦数据库实战:备份恢复与数据迁移全攻略(实例初始化、服务注册、路径迁移)
数据库·chrome
SelectDB技术团队32 分钟前
2026 SelectDB AI 产品发布会:Agent Native 数据基础设施能力全景发布
数据库·人工智能·agent·apache doris·selectdb
爱吃羊的老虎40 分钟前
【数据库】模块一:数据库基础与关系代数
数据库
dishugj1 小时前
iSCSI + Multipath + ASM:Oracle RAC 共享存储技术链详解
数据库·oracle
yoothey2 小时前
MySQL事务机制解析 - 面试高分知识点
数据库·mysql·面试
swordbob2 小时前
NIO 的 Channel 里有多个 BIO 吗?
linux·网络·nio
Fcy6482 小时前
Linux下 信号的保存与捕捉
linux·中断·信号的捕捉·信号的保存
Lkstar2 小时前
万字长文Query改写与多路召回实战|从HyDE到RRF融合,召回率提升22%的完整方案
数据库·人工智能·llm
IT新视界2 小时前
星环科技ArgoDB:基于一体化架构构建数据全生命周期安全底座
数据库·科技·安全·架构