在过程中设置TMP环境变量后,无法打开与Jet数据库的OleDbConnection

如何解决在过程中设置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设置为与该过程中的代码相同的外壳程序文件夹,我仍然会收到错误消息。如果在此过程中的代码中设置了其他环境变量,我会收到错误消息。

更新
如果在用户级别设置TMP环境变量,则看不到错误

Environment.SetEnvironmentvariable("TMP","<sibling to Jet database>",EnvironmentvariableTarget.User);  

不幸的是,这对我不起作用,因为我只希望在进程范围内更改TMP环境变量,而不影响计算机上的其他进程。

解决方法

如果将TMP环境变量设置为不存在的文件夹,则会出现此错误。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?