Access 数据库 - QODBC 驱动程序对管理员执行授权

Access Database - QODBC Driver Execute Grant On Admin

尝试使用我的 .accdb 文件执行以下语句时:

grant select on MSysObjects to Admin;

我从 QSqlError::text() 得到以下信息:

encountered SQL Error [[Microsoft][ODBC Microsoft Access Driver] Cannot open the Microsoft Access database engine workgroup information file. ODBC3: Unable to execute statement]

我知道如果您有损坏或丢失的 System.mdw 文件,此问题可能会在 .net 环境中出现。上述文件存在于以下目录中:

C:\Users\%USERNAME%\AppData\Roaming\Microsoft\Access

我正在尝试 运行 SQL 使用 Qt 框架使用 QODBC 进行查询。这是 Qt 框架的一些限制吗?还是我在这里遗漏了一些明显的东西?我尝试将 System.mdw 文件移动到我的应用程序 bin 目录中以查看是否有帮助(认为应用程序可能无法找到有问题的文件)但不幸的是它没有任何区别。

我正在使用 Qt 5.12.0。

我需要将参数 SystemDB 添加到我的连接字符串中以消除此错误,如 Microsoft Access accdb ODBC Driver[= 下的连接字符串中所述16=] 在下一页:https://www.connectionstrings.com/access/

Driver={Microsoft Access Driver (*.mdb, *.accdb)};Dbq=C:\mydatabase.accdb;
SystemDB=C:\mydatabase.mdw;