qtsql连接达梦数据库

odbc

window和linux都有odbc的中间件,可以通过odbc中间件配合qtsql连接数据库

  • windows下配置odbc
  • linux配置odbc

apt install unixodbc unixodbc-dev

/etc/odbcinst.ini配置

ini 复制代码
[DM8 ODBC DRIVER]
Description=DM8 ODBC Driver
DRIVER=/opt/dmdbms/bin/libdodbc.so

/etc/odbc.ini配置

ini 复制代码
[dm8]
Description=DM8 Database
DRIVER=DM8 ODBC DRIVER
SERVER=localhost
TCP_PORT=5236
UID=SYSDBA
PWD=SYSDBA

isql -v dm8测试连接是否成功

qt

使用qt6 构建项目

c 复制代码
aux_source_directory(. code)
find_package(Qt6 COMPONENTS REQUIRED Core Sql Gui Widgets Network PATHS d:/tools/qt/6.6.0/msvc2019_64/lib/cmake)

add_executable(dameng ${code})
target_link_libraries(dameng Qt6::Core Qt6::Sql)

chatgpt提示的代码如下:

c 复制代码
#include <QCoreApplication>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QSqlRecord>
#include <QSqlError>
#include <QDebug>

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

    // 添加数据库驱动
    QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
    // 设置数据库文件路径
    db.setDatabaseName("dm");

    // 打开数据库
    if (!db.open()) {
        qDebug() << "Failed to open database:"<<db.lastError().text();
        return -1;
    }

    // 创建查询对象
    QSqlQuery query;
    // 执行查询语句
    if (!query.exec("SELECT * FROM \"SYS\".sysuser$")) {
        qDebug() << "Query failed: " << query.lastError().text();
        return -1;
    }

    QSqlRecord record = query.record();
    // 遍历查询结果
    while (query.next()) {
        for (int i = 0; i < record.count(); ++i) {
            qDebug() << record.fieldName(i) <<":"<< query.value(i).toString();
        }
        qDebug()<<"--------------------";
    }

    // 关闭数据库
    db.close();

    return a.exec();
}

exception

  • no driver load

qtsql的driver在plugin的sqldriver目录里面,通过动态加载目录里面的文件加载driver

  • 加密模块加载失败, HY000 QODBC: Unable to connect

达梦数据库bin文件中,拷贝ssleay32、libeay32两个文件

  • isql 提示[ISQL]ERROR: Could not SQLConnect

检查/etc/odbc.ini中的配置是否正确,driver和odbcinst.ini的名称一致

  • 提示libdodbc.so找不到

ldd libdodbc.so 是否有找不到的文件,需要配置环境变量LD_LIBRARY_PATH

相关推荐
偶像你挑的噻2 分钟前
3.Qt-基础布局以及事件
开发语言·数据库·qt
Dxy123931021616 分钟前
MySQL如何做读写分离架构
数据库·mysql·架构
毕设十刻1 小时前
基于Vue的考勤管理系统8n7j8(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
合方圆~小文2 小时前
不同画面,三个镜头实时监控拍摄方案
数据结构·数据库·人工智能
ChrisitineTX3 小时前
凌晨突发Java并发问题:synchronized锁升级导致接口超时,排查过程全记录
java·数据库·oracle
极限实验室3 小时前
Easysearch 2.0.0 性能测试
数据库·性能优化
老华带你飞4 小时前
社团管理|基于Java社团管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
shayudiandian4 小时前
用LangChain打造你自己的智能问答系统
java·数据库·langchain
马克学长4 小时前
SSM特殊教育学校学生管理系统002k1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理系统·特殊教育·ssm 框架
卿雪5 小时前
Redis 线程模型:Redis为什么这么快?Redis为什么引入多线程?
java·数据库·redis·sql·mysql·缓存·golang