如何解决在过程中设置TMP环境变量后,无法打开与Jet数据库的OleDbConnection
在此过程的早期,我将TMP环境变量设置为Jet数据库所在的同级文件夹。我使用以下代码:
Environment.SetEnvironmentvariable("TMP","<sibling to Jet database>");
致电OleDbConnection.open()
时收到错误消息。
这是堆栈跟踪:
System.Data.OleDb.OleDbException (0x80004005): Unspecified error
at System.Data.OleDb.OleDbConnectionInternal..ctor(OleDbConnectionString constr,OleDbConnection connection)
at System.Data.OleDb.OleDbConnectionFactory.CreateConnection(DbConnectionoptions options,DbConnectionPoolKey poolKey,Object poolGroupProviderInfo,DbConnectionPool pool,DbConnection owningObject)
at System.Data.ProviderBase.DbConnectionFactory.CreateConnection(DbConnectionoptions options,DbConnection owningConnection,DbConnectionoptions userOptions)
at System.Data.ProviderBase.DbConnectionFactory.CreateNonPooledConnection(DbConnection owningConnection,DbConnectionPoolGroup poolGroup,DbConnectionoptions userOptions)
at System.Data.ProviderBase.DbConnectionFactory.TryGetConnection(DbConnection owningConnection,taskcompletionsource`1 retry,DbConnectionoptions userOptions,DbConnectionInternal oldConnection,DbConnectionInternal& connection)
at System.Data.ProviderBase.DbConnectionInternal.TryOpenConnectionInternal(DbConnection outerConnection,DbConnectionFactory connectionFactory,DbConnectionoptions userOptions)
at System.Data.ProviderBase.DbConnectionClosed.TryOpenConnection(DbConnection outerConnection,DbConnectionoptions userOptions)
at System.Data.ProviderBase.DbConnectionInternal.OpenConnection(DbConnection outerConnection,DbConnectionFactory connectionFactory)
at System.Data.OleDb.OleDbConnection.open()
如果我在运行进程之前在外壳中设置了环境变量,而不是在进程中的代码中设置了环境变量,则不会收到错误消息。
set TMP=<sibling to Jet database>
这是我的连接字符串:
Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\<sibling to TMP>\\database.mdb;
我试图创建一个示例控制台应用程序,但是不表现出相同的行为。在那里工作。我看到错误的应用程序是WinForms应用程序,其目标.NET Framework版本设置为.NET 4.6.1。
在TMP环境变量的值中指定的文件夹存在,并且权限设置为完全控制所有人。
即使我将TMP设置为与该过程中的代码相同的外壳程序文件夹,我仍然会收到错误消息。如果在此过程中的代码中设置了其他环境变量,我会不收到错误消息。
Environment.SetEnvironmentvariable("TMP","<sibling to Jet database>",EnvironmentvariableTarget.User);
不幸的是,这对我不起作用,因为我只希望在进程范围内更改TMP环境变量,而不影响计算机上的其他进程。
解决方法
如果将TMP环境变量设置为不存在的文件夹,则会出现此错误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。