Qt6.5.3 mingw64 Ninja编译oracle oci驱动

Qt6.5.3 mingw64 编译oracle oci

1.下载oracle install client,主要是basic 和 sdk。

2.将sdk和basic的内容复制到一起,basic中的instantclient_xx_x目录下的内容,sdk的instantclient_xx_xx目录下的内容。

构成如下的目录结构

oracleBSPath/

├── include/ ← 头文件(来自 sdk/include)

├── lib/liboci.a ← MinGW 库

├── oci.dll

└── sdk/ ← 原始目录(可保留,但非必需)

3.将oci.dll生成mingw64支持的.a库

bash 复制代码
	gendef oci.dll  
	dlltool -d oci.def -l liboci.a -D oci.dll
	生成一个liboci.a,这是 MinGW 链接所需的关键文件

4.切换到Qt源码中的路径下,我的路径

c 复制代码
C:\DevelopSoftware\Qt6\6.5.3\Src\qtbase\src\plugins\sqldrivers

执行命令

bash 复制代码
	mkdir build
	cd build
	使用如下命令,具体的可以根据自己的目录修改

执行cmake命令

powershell 复制代码
cmake -G Ninja -DCMAKE_BUILD_TYPE=Debug -DCMAKE_MAKE_PROGRAM="C:/DevelopSoftware/Qt6/Tools/Ninja/ninja.exe" -DCMAKE_C_COMPILER="C:/DevelopSoftware/Qt6/Tools/mingw1120_64/bin/gcc.exe" -DCMAKE_CXX_COMPILER="C:/DevelopSoftware/Qt6/Tools/mingw1120_64/bin/g++.exe" -DCMAKE_PREFIX_PATH="C:/DevelopSoftware/Qt6/6.5.3/mingw_64;C:/DevelopSoftware/Oracle/oracleBSPath/sdk" -DQT_FEATURE_sql_oci=ON  -DQT_FEATURE_sql_mysql=OFF -DQT_FEATURE_sql_psql=OFF -DQT_FEATURE_sql_odbc=OFF -DQT_FEATURE_sql_tds=OFF -DQT_FEATURE_sql_db2=OFF -DQT_FEATURE_sql_sqlite=OFF -DQT_FEATURE_sql_ibase=OFF ../
  1. 执行如下,生成qsqloci.dll
powershell 复制代码
ninja qsqloci
  1. 生成位置在build/plugins/sqldrivers/qsqloci.dll

  2. 复制 qsqloci.dll 到 自己的项目的运行路径下的**/plugins/sqldrivers/**

  3. 复制basic中的dll,oci.dll, oraociei19.dll 到 exe 同目录(最好全部的dll都复制)

相关推荐
少控科技19 小时前
QT新手日记 029 - QT所有模块
开发语言·qt
2501_9445215919 小时前
Flutter for OpenHarmony 微动漫App实战:骨架屏加载实现
android·开发语言·javascript·数据库·redis·flutter·缓存
l1t19 小时前
将追赶法求连续区间的Oracle SQL改写成DuckDB
数据库·sql·oracle·duckdb
时艰.19 小时前
Redis 核心知识点归纳与详解
数据库·redis·缓存
莞理员19 小时前
新老数据库表同步问题
数据库
聆风吟º1 天前
Oracle到KingbaseES数据库迁移:全流程实战指南与避坑总结
数据库·oracle·数据库迁移·kingbasees
哈__1 天前
Oracle至KingbaseES数据库迁移全攻略:痛点拆解、配置实操与问题排查
数据库·oracle
JZC_xiaozhong1 天前
电商ERP如何同步订单数据到MySQL?集成方案解析
数据库·mysql·数据分析·etl工程师·嵌入式实时数据库·电商erp集成·数据集成与应用集成
消失的旧时光-19431 天前
第四篇(实战): 订单表索引设计实战:从慢 SQL 到毫秒级
java·数据库·sql
知识分享小能手1 天前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)
数据库·学习·oracle