Qt QOCI driver available but not loaded(可用但未加载)

参考Linux Qt 6安装Oracle QOCI SQL Driver插件(适用WSL),根据SQL Database Drivers成功将libqsqloci.soqsqloci.debug等文件安装到/opt/Qt6.8.2/6.8.2/gcc_64/plugins/sqldrivers后,运行Qt程序并尝试连接数据库时仍然报错

QSqlError("", "Driver not loaded", "Driver not loaded")

参考Cannot load QOCI SQL driver even successfully built。经确认,LD_LIBRARY_PATHPATH均添加了Oracle客户端路径(~/software/Oracle,即libclntsh.so所在的目录),并添加了ORACLE_HOME环境变量(注意:如果Oracle客户端为instant client,则不应设置该环境变量)。经QSqlDatabase: QOCI driver not loaded提醒,在Qt Creator中左边栏的"项目",在左分栏中的"构建与运行"中选择相应的Kit(例如Desktop Qt 6.8.2)的"运行"一栏,在右分栏中打开"运行设置",在"环境"一栏中展开"详情",点击"添加(A)"添加环境变量,在右侧的文本输入框中输入QT_DEBUG_PLUGINS=1,然后重新运行Qt程序并尝试连接数据库,显示详细报错:

libclntsh.so.21.1 cannot open shared object file: No such file or directory

在shell中通过ldd libqsqloci.so命令检查动态对象的链接情况,显示

libclntsh.so.21.1 => /home//software/Oracle/libclntsh.so.21.1 (0x000075fe63a00000)

同时其他so文件同样正常链接。参考"libclntsh.so: cannot open shared object file in ubuntu to run python program in Spark Clusterlibclntsh.so.11.1: cannot open shared object file.,在/etc/ld.so.conf.d/目录下新建文件oracle-client.conf,并输入/home/<username>/software/Oracle作为文件内容,然后执行sudo ldconfig。再次运行Qt程序并连接数据库,成功。

相关推荐
ajassi20007 分钟前
开源 C++ QT QML 开发(九)文件--文本和二进制
c++·qt·开源
IT 小阿姨(数据库)12 分钟前
PostgreSQL通过pg_basebackup物理备份搭建流复制备库(Streaming Replication Standby)
运维·服务器·数据库·sql·postgresql·centos
-森屿安年-16 分钟前
C++ 类与对象
开发语言·c++
ajassi200025 分钟前
开源 C++ QT QML 开发(八)自定义控件--圆环
c++·qt·开源
小蒜学长40 分钟前
springboot基于javaweb的小零食销售系统的设计与实现(代码+数据库+LW)
java·开发语言·数据库·spring boot·后端
会开花的二叉树1 小时前
c语言贪吃蛇游戏开发
c语言·开发语言
韩立学长1 小时前
【开题答辩实录分享】以《C#大型超市商品上架调配管理系统的设计与实现》为例进行答辩实录分享
开发语言·c#
tao3556672 小时前
【Python刷力扣hot100】49. Group Anagrams
开发语言·python·leetcode
龙腾AI白云2 小时前
大模型-扩散模型(Diffusion Model)原理讲解(4)
开发语言
他们叫我技术总监2 小时前
Oracle数据库常见问题实战:从连接错误到自动清理空闲会话
数据库·oracle