Qt6编译达梦8数据库驱动插件
一、编译环境
操作系统:deepin V23
Qt版本: Qt 6.7.2
编译器:gcc/g++ version 12.3.0,cmake 3.28.3
达梦数据库:开发版V8
二、下载达梦QT接口源码
下载链接:
https://eco.dameng.com/download/?_blank
下载Qt编译qt_src-1113-20240428.zip,将其中dm_57中源代码解压至
${QTHOME}/6.7.2/Src/qtbase/src/plugins/sqldrivers/dm 目录下
三、修改Qt编译相关配置文件
1. CMakeLists.txt
${QTHOME}/6.7.2/Src/qtbase/src/plugins/sqldrivers/CMakeLists.txt
#### if(QT_FEATURE_sql_db2) 行前插入
if(QT_FEATURE_sql_dm)add_subdirectory(dm)
endif()
2. configure.cmake
${QTHOME}/6.7.2/Src/qtbase/src/plugins/sqldrivers/configure.cmake
#### Libraries 部分 qt_find_package(ODBC 行前插入
qt_find_package(DM PROVIDED_TARGETS DM::DM MODULE_NAME sqldrivers QMAKE_LIB dm)
#### Features 部分 qt_feature("sql-odbc" 行前插入
qt_feature("sql-dm" PRIVATELABEL "DM (DaMeng)"CONDITION DM_FOUND
)
#### 最后一段中qt_configure_add_summary_entry(ARGS "sql-odbc")行前插入
qt_configure_add_summary_entry(ARGS "sql-dm")
3.qt_cmdline.cmake
${QTHOME}/6.7.2/Src/qtbase/src/plugins/sqldrivers/qt_cmdline.cmake
#### qt_commandline_option(sql-odbc TYPE boolean)行前插入
qt_commandline_option(sql-dm TYPE boolean)
#### qt_commandline_option(plugin-sql-odbc TYPE void NAME sql-odbc)行前插入
qt_commandline_option(plugin-sql-dm TYPE void NAME sql-dm)
4.编写FindDM.cmake文件
${QTHOME}/6.7.2/gcc_64/lib/cmake/Qt6/FindDM.cmake
5.编写DMConfig.cmake文件
${DM_DIR}/DMConfig.cmake
四、配置环境变量
加入~/.bashrc:
export QTHOME=/home/${USER}/Qt
export QTVER=6.7.2
export QTDIR=$QTHOME/$QTVER
export PATH=$PATH:$QTDIR/gcc_64/bin:$QTHOME/Tools/CMake/bin
export LD_LIBRARY_PATH=$QTDIR/gcc_64/lib:$LD_LIBRARY_PATH
export QTBASE=$QTDIR/Src/qtbase
export DM_DIR=/home/${USER}/dmdbms
export LD_LIBRARY_PATH=$QM_DIR/drivers/dpi:$LD_LIBRARY_PATH
五、创建编译目录
~$ mkdir ~/build-qdm && cd ~/build-qdm
六、生成CMAKE编译文件
$ qt-cmake -G Ninja $QTBASE/src/plugins/sqldrivers \
-DDM_INCLUDE_DIR="$DM_DIR/include" \
-DDM_LIBRARY="$DM_DIR/drivers/dpi/libdmdpi.so" \
-DCMAKE_MAKE_PROGRAM="$QTHOME/Tools/Ninja/ninja"
七、编译构建
生成的oci驱动插件包目录为:$BUILD-DM/plugins/sqldrivers
$ cmake --build .
八、安装
安装路径为 $CMAKE_INSTALL_PREFIX/plugins/sqldrivers
$ cmake --install .
九、Qt测试代码:
#include <QCoreApplication>
#include <QSqlDatabase>
#include <QSqlError>
#include <QDebug>int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);QSqlDatabase db=QSqlDatabase::addDatabase("QDM");db.setHostName("localhost");db.setDatabaseName("DMSERVER");db.setPort(5236);db.setUserName("SYSDBA");db.setPassword("SYSDBA");bool ret=db.open();qDebug()<<"db open is "<<ret;if (!query.exec(sql)){qDebug()<<query.lastError();return false;}db.close();a.exit();
}
相关文章:
Qt6编译达梦8数据库驱动插件
一、编译环境 操作系统:deepin V23 Qt版本: Qt 6.7.2 编译器:gcc/g version 12.3.0,cmake 3.28.3 达梦数据库:开发版V8 二、下载达梦QT接口源码 下载链接: https://eco.dameng.com/downlo…...
什么是机器学习力场
机器学习力场(Machine Learning Force Fields, MLFF)方法是一类将机器学习技术应用于分子动力学(Molecular Dynamics, MD)模拟的技术。它通过使用机器学习算法拟合原子之间的相互作用能量和力场,使得在不牺牲精度的前提…...
USB组合设备——串口+鼠标+键盘
文章目录 USB组合设备——串口+鼠标+键盘描述符结构设备描述符配置描述符集合配置描述符接口关联描述符键盘接口描述符鼠标接口描述符类特殊命令CDC 的类特殊命令HID 的类特殊命令接口 2接口3USB组合设备——串口+鼠标+键盘 描述符结构 设备描述符 配置描述符 接口关联描述符…...
python学习——对无人机影像有RGB转换到HSV
问题描述 最近需要对无人机影像中绿色植被信息进行提取,查看相关论文,发现用的比较多的就是HSV色彩转换方法,动手实践一下。 解决思路 #mermaid-svg-5ejGodIusPv6zFVS {font-family:"trebuchet ms",verdana,arial,sans-serif;fon…...
【南方科技大学】CS315 Computer Security 【Lab2 Buffer Overflow】
目录 引言软件要求启动虚拟机环境设置禁用地址空间布局随机化(ASLR)设置编译器标志以禁用安全功能 概述BOF.ctestShellCode.c解释 createBadfile.c 开始利用漏洞在堆栈上查找返回地址 实验2的作业 之前有写过一个 博客,大家可以先看看栈溢出…...
持续集成与持续交付CI/CD
CI/CD 是指持续集成(Continuous Integration)和持续部署(Continuous Deployment)或持续交付(Continuous Delivery) 持续集成(Continuous Integration) 持续集成是一种软件开发实践&…...
C++学习笔记之变量作用域
C学习笔记之变量作用域 https://www.runoob.com/cplusplus/cpp-variable-scope.html 在C程序中,通常有 3 个地方可以声明变量 在函数或者代码块当中,为局部变量在函数的参数定义中,为形式参数在所有函数的外部,为全局变量 作用域…...
解决跨境电商平台账号无法访问的常见问题
跨境电商的迅猛发展,越来越多的卖家选择在全球各大电商平台如亚马逊、eBay等进行商品销售。然而,在实际运营过程中,卖家经常会遇到账号无法访问、应用打不开等问题,导致业务受阻。本文将针对这些问题进行详细分析,并提…...
P2847 [USACO16DEC] Moocast G
P2847 [USACO16DEC] Moocast G [USACO16DEC] Moocast G 题面翻译 Farmer John 的 N N N 头牛 ( 1 ≤ N ≤ 1000 1 \leq N \leq 1000 1≤N≤1000) 为了在他们之间传播信息,想要组织一个"哞哞广播"系统。奶牛们决定去用步话机装备自己而不是在很远的距离…...
针对国内AIGC市场,国内目前出台了那些法律法规?
针对国内AIGC市场,特别是AI生成与合成内容方面,中国已经出台了一系列法律法规来规范其发展和应用。 图片源自“央视新闻” 以下是一些主要的法律法规: 一、国家层面的法律法规 《中华人民共和国网络安全法》 施行时间:2017年6月…...
Windows+Ubuntu双系统下时钟设置
Ubuntu默认把系统时间(硬件时钟)设置为UTC时间,并根据本地时区和夏令时设置自动调整本地时间,这是一种很合理很优雅的处理硬件时钟和本地时钟的模式。而Windows系统是默认情况下把系统时间设置为本地时间,历来独霸电脑…...
一些写leetcode的笔记
标准库中的string类没有实现像C#和Java中string类的split函数,所以想要分割字符串的时候需要我们自己手动实现。但是有了stringstream类就可以很容易的实现,stringstream默认遇到空格、tab、回车换行会停止字节流输出。 #include <sstream> #incl…...
shopify主题开发之template模板解析
在 Shopify 主题开发中,template 文件是核心部分,它们定义了店铺中不同页面的布局和结构。下面将详细介绍 Shopify 主题中的 template 模板。 一、template 文件结构 在 Shopify 主题中,templates 文件夹包含了所有用于生成店铺页面的模板文…...
Zookeeper学习
文章目录 学习第 1 章 Zookeeper 入门1.1 概述Zookeeper工作机制 1.2 特点1.3 数据结构1.4 应用场景统一命名服务统一配置管理统一集群管理服务器动态上下线软负载均衡 1.5 下载zookeeper 第 2 章 Zookeeper 本地安装2.1 本地模式安装安装前准备配置修改操作 Zookeeper本地安装…...
FAT32文件系统详细分析 (格式化SD nandSD卡)
FAT32 文件系统详细分析 (格式化 SD nand/SD 卡) 目录 FAT32 文件系统详细分析 (格式化 SD nand/SD 卡)1. 前言2.格式化 SD nand/SD 卡3.FAT32 文件系统分析3.1 保留区分析3.1.1 BPB(BIOS Parameter Block) 及 BS 区分析3.1.2 FSInfo 结构扇区分析3.1.3 引导扇区剩余扇区3.1.4 …...
通义灵码在Visual Studio上
通义灵码在Visual Studio上不好用,有时候会出现重影,不如原生的自动补全好用,原生的毕竟的根据语法来给出提示的。...
基于SpringBoot的招生宣传管理系统【附源码】
基于SpringBoot的招生宣传管理系统(源码L文说明文档) 目录 4 系统设计 4.1 系统概述 4.2系统功能结构设计 4.3数据库设计 4.3.1数据库E-R图设计 4.3.2 数据库表结构设计 5 系统实现 5.1管理员功能介绍 5.1.1管理员登录 …...
SOT23封装1A电流LDO具有使能功能的 1A、低 IQ、高精度、低压降稳压器系列TLV757P
前言 SOT23-5封装的外形和丝印 该LDO适合PCB空间较小的场合使用,多数SOT23封装的 LDO输出电流不超过0.5A。建议使用时输入串联二极管1N4001,PCB布局需要考虑散热,参考文末PCB布局。 1 特性 • 采用 SOT-23 (DYD) 封装,具有 60.3C/W RθJA •…...
python绘制3d建筑
import matplotlib.pyplot as plt import numpy as np from mpl_toolkits.mplot3d.art3d import Poly3DCollection# 随机生成建筑块数据 def generate_building_blocks(num_blocks, grid_size100, height_range(5, 50), base_size_range(10, 30)):buildings []for _ in range(…...
机器学习实战21-基于XGBoost算法实现糖尿病数据集的分类预测模型及应用
大家好,我是微学AI,今天给大家介绍一下机器学习实战21-基于XGBoost算法实现糖尿病数据集的分类预测模型及应用。首先阐述了 XGBoost 算法的数学原理及公式,为模型构建提供理论基础。接着利用 kaggle 平台的糖尿病数据集,通过详细的…...
开箱即用:基于Qwen3-Embedding-4B的智能文档检索系统搭建实录
开箱即用:基于Qwen3-Embedding-4B的智能文档检索系统搭建实录 1. 引言:为什么选择Qwen3-Embedding-4B 想象一下,你手头有成千上万份技术文档、合同或学术论文,每次查找相关内容都要靠关键词匹配,结果要么漏掉重要信息…...
深度学习项目训练环境作品集:10类常见图像分类任务的统一训练模板与结果汇总
深度学习项目训练环境作品集:10类常见图像分类任务的统一训练模板与结果汇总 1. 环境准备与快速上手 深度学习项目训练往往需要复杂的环境配置,从框架安装到依赖库配置,整个过程耗时且容易出错。本镜像基于深度学习项目改进与实战专栏&…...
学术利器爱毕业aibye推荐六款顶尖平台,智能改写与写作功能双管齐下,优化研究流程
工具名称 核心功能 特色优势 Aibiye 论文生成降AI率 全学科覆盖、仿写优化、自动图表生成 Aicheck AI检测文献综述辅助 精准查新、3分钟高效成文 GPT学术版 润色/翻译/代码解释 多模型协同、PDF深度解析 摆平论文 大纲生成降重改写 三步出稿、本硕博通用 QuillB…...
DeepSeek LeetCode 1125.最小的必要团队 public int[] smallestSufficientTeam(String[] req_skills, List<List
这是 LeetCode 1125 “最小的必要团队”问题。要求从候选人中选择一个最小的团队,使得团队成员的技能集合覆盖所有必需的技能。问题理解 有一个技能需求列表 req_skills,如 ["java", "python", "cpp"]有 people 列表&…...
OpenClaw+千问3.5-27B创作助手:从大纲到公众号图文全自动生成
OpenClaw千问3.5-27B创作助手:从大纲到公众号图文全自动生成 1. 为什么需要全自动创作助手 作为一个技术博主,我每周都要产出2-3篇技术文章。最痛苦的环节不是写作本身,而是那些重复性的准备工作:构思大纲、寻找配图、调整格式、…...
NodeList 对象
NodeList 对象 概述 NodeList 对象是 DOM(文档对象模型)中的一种数据结构,它代表了包含在一个父节点内的所有元素节点的一个集合。NodeList 对象常用于处理文档中的多个元素,是 JavaScript 在操作 DOM 时的一个重要工具。 特点 1. 长度属性 NodeList 对象具有一个 len…...
如何快速上手接口测试?
🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 大量线上BUG表明,对接口进行测试可以有效提升产品质量,暴露手工测试时难以发现的问题,同时也能缩短测试周期,提升测…...
Cadence Virtuoso保姆级教程:从零完成反相器版图绘制、DRC到后仿真的完整流程
Cadence Virtuoso保姆级教程:从零完成反相器版图绘制、DRC到后仿真的完整流程 在集成电路设计领域,Cadence Virtuoso是业界公认的标准工具之一。对于初学者而言,掌握从原理图到版图再到后仿真的完整流程至关重要。本文将带领你一步步完成反相…...
文件夹的修改日期可以改吗?分享你三个修改方法
在电脑文件管理中,系统不支持直接修改文件夹的「修改时间」,但日常整理文件、统一项目时间戳、还原备份文件夹时间、办公归档时,经常需要自定义修改这个属性。本文给大家整理了3 种实用方法:第一种是汇帮批量重命名工具࿰…...
基于西门子S7-200 PLC与组态王技术的变频恒压供水控制系统设计与实物制作——软硬件设计详解
基于西门子S7-200 PLC和组态王小区变频恒压供水控制系统的设计,可制作对应实物,软硬件设计今天,我决定深入研究一个自动化控制领域中的典型项目:基于西门子S7-200 PLC和组态王软件的小区变频恒压供水控制系统。这个项目听起来有点…...
