Qt 操作数据库报错:QSqlDatabase: QSQLITE driver not loaded

本文解决Clion+Qt环境下运行程序出现QSqlDatabase:QSQLITEdrivernotloaded错误的问题。通过将sqldrivers文件夹放置于可执行文件同一目录下,确保程序能够正确加载SQLite动态链接库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在解决了Clion + Qt的数据库问题后《Clion + Qt 添加SQLite数据库》,又遇到了新的问题,在运行程序时,出现QSqlDatabase: QSQLITE driver not loaded错误

使用下面语句输出支持的数据库,会输出空

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

最后发现,在添加了Sql模块后,是不够的,还需要将相关动态链接库拷贝到应用程序运行路径下。

解决方案

首先,去Qt的安装路径下,进入plugins文件夹
我的Qt plugins路径

E:\Qt\Qt5.14.2\5.14.2\mingw73_64\plugins

找到sqldrivers文件夹,直接把这个文件夹拷贝到可执行程序的路径下。不是在工程目录下,(当然,不同环境可能也有差异)比如我这里使用的是Clion编写的Qt程序,路径就是cmake-build-debug
在这里插入图片描述
在这里插入图片描述
再次运行,那条语句就会输出(因为我只保留了qsqlite.dll文件)
在这里插入图片描述

注意

虽然上述已经说过了,但自己也测试过,单独把qsqlite.dll动态库文件拷贝到程序根路径是不行的,必须在sqldrivers文件夹下。
在这里插入图片描述

### Qt 连接达梦数据库 QODBC 驱动未加载解决方案 当遇到 `QSqlDatabase: QODBC driver not loaded` 的问题时,通常是因为 ODBC 驱动程序未能正确加载或配置不当。以下是详细的排查和解决方法: #### 1. 确认可用驱动列表 确认当前环境中已安装并可使用的 SQL 驱动包括但不限于 `QSQLITE`, `QMYSQL`, 和 `QODBC`[^1]。 #### 2. 安装必要的依赖项 确保已经安装了适用于目标操作系统的 ODBC 驱动管理器以及特定于达梦数据库的 ODBC 驱动程序。对于 Windows 用户来说,这可能意味着下载并安装 Microsoft Data Access Components (MDAC) 或者 UnixODBC 对应版本。 #### 3. 设置环境变量 为了使应用程序能够找到所需的动态链接库(DLL),需设置 PATH 环境变量指向包含这些 DLL 文件的位置。特别是如果手动复制了任何第三方提供的插件至 Qt 插件目录,则更应该这样做。 #### 4. 复制必需的文件到指定位置 按照描述的操作指南,将相关联的 `.dll` 文件放置在适当的地方以便 Qt 能够访问它们。例如,可以考虑把 `qsqlodbc.dll` 放入 `%QT_HOME%\plugins\sqldrivers` 下面,并且同样处理其他依赖性的共享对象/模块如 `libdm8_odbc.so` 或其对应平台上的变体形式[^3]。 #### 5. 使用正确的编译工具链 选择合适的编译器非常重要;不同架构下的二进制兼容性和 ABI 差异可能会引起意想不到的问题。文中提到的例子使用了 MinGW-w64 来构建项目,因此推荐保持一致的选择以减少潜在冲突的可能性。 #### 6. 检查 PostgreSQL 相关提示 虽然问题是关于达梦而非 PostgreSQL ,但是某些通用原则仍然适用——比如避免将软件部署在一个含有空格字符在内的路径之中,因为这类情况有时会干扰命令行解析逻辑或者造成难以诊断的小错误[^4]。 通过上述措施应当有助于缓解乃至彻底解决问题。当然,具体实施细节还需参照官方文档和个人开发环境的具体情况进行调整优化。 ```cpp // 示例代码展示如何创建一个新的数据库连接 #include <QtSql/QSqlDatabase> #include <QDebug> int main() { QSqlDatabase db = QSqlDatabase::addDatabase("QODBC"); db.setHostName("your_host_name"); // 替换成实际主机名 db.setPort(your_port_number); // 替换成端口号 db.setDatabaseName("DM_DSN_NAME");// DSN 名字, 即数据源名称 bool ok = db.open(); qDebug() << "Connection successful:" << ok; } ```
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值