未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序。
触发原因:使用64位程序,并且使用Provider=Microsoft.Jet.OLEDB.4.0作为Access数据库的连接字符串。
问题详情可以参考微软的这个解释:适用于 Jet 和 ODBC 驱动程序的 OLE DB 提供程序仅是 32 位版本 - Microsoft 365 Apps | Microsoft Learn
解决方式参考:
- 使用32位程序连接Access
- 更改连接字符串,使用AccessDatabaseEngine,详情可参考下个问题
未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序
触发原因:创建的程序位数和安装的Access位数不匹配
连接字符串中的ACE,即Access 数据库引擎也称为 Access Connectivity Engine,是基于 Jet 的基础构建的 Office 数据库引擎。 ACE 在 32 位和 64 位体系结构中都提供。假设一个环境,安装的是32位Access,但连接程序必须是64位的(或者反过来,32位程序连接64位Access),重新安装office太麻烦,这里可以参考微软给出的这个解释:无法建立与 Access 数据库引擎 OLE DB 的连接 - Power Automate | Microsoft Learn
解决方式参考:
- 将程序改为和Access相同的位数
- 安装和程序位数相同的AccessDatabaseEngine
默认安装的AccessDatabaseEngine.exe必须和office位数一致,如果需要不同位数的AccessDatabaseEngine.exe共存,可以参考上述链接,使用**/quiet**参数静默安装程序
字段或者别名中存在特殊字符
可以用方括号将该名称括起来。 如果名称不含任何空格或特殊字符(例如标点符号),则方括号为可选项。 如果名称含有空格或特殊字符,则必须使用方括号。
比如:时速(km/h),要写为**[时速(km/h)]**
------------------2024/04/06