如何从我的开发环境中的Windows 7 x64上的C#连接到Oracle数据库
|
在 Windows 7×64上连接到Oracle数据库时遇到困难 我的环境如下: > Windows 7×64 我将所有项目的目标CPU显式地定义为x86 CPU(而不是Any或x86) 我使用DbProviderFactory.GetFactory连接 我的app.config中的ConnectionString条目如下所示: <add name="MYORACLE" connectionString = "User ID=MYPASSWORD;Password=MYPASSWORd;Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=MYHOST)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=MYSERVICE)));" providerName="System.Data.OracleClient" /> (我尝试过各种样式的连接字符串,没有成功) 当我编译应用程序时,如果我从Debug文件夹运行可执行文件,它可以正常连接.但是,如果我尝试在Visual Studio中运行它,它将在打开连接时失败 ORA-06413: Connection not open.n 这是一个如何被调用的例子: [TestMethod]
public void ConnectToOracle_Success()
{
var connectionStringSettings = ConnectionBuilder.GetConnectionStringSetting(OracleConnectionName);
var providerFactory = ConnectionBuilder.GetProviderFactory(connectionStringSettings);
ConnectionBuilder.ValidateConnectionString(connectionStringSettings);
using (var connection = providerFactory.CreateConnection())
{
Assert.IsNotNull(connection);
connection.ConnectionString = connectionStringSettings.ConnectionString;
try
{
connection.Open();
}
catch (Exception e)
{
Assert.Equals(e.Message,"");
}
}
}
我在Windows 7×64上看到与Visual Basic 6类似的东西,而Oracle不喜欢安装它的路径(即括号“程序(x86)”).这是同样的事情,还是有另一种方式来说服甲骨文的行为. 哦,Oracle提供者中可怕的括号.最简单的方法是使用更新版本的客户端,问题被修复.使用Oracle 10g数据库,您可以安全地使用高达12.1.x的客户端(可从这里获得: 64-bit Oracle Data Access Components).使用64位操作系统,我使用了另一个技巧:首先安装32-bit版本的客户端,并安装64位版本.这样一些应用程序,如Office或旧的VS dev Web服务器仍然可以工作. (编辑:鞍山站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 如何使用Choco在Windows 10上安装Visual Studio代码
- Windows机器的正常运行时间
- 微软向所有Windows 11用户开放新Emoji被用户吐槽 依旧是2D
- 微软 Window 11 Build 22504.1010 KB5008697 预览版推出
- windows-server-2008 – 无法连接到Windows Server 2008R2上
- 解密ASP源代码
- 如何在Windows 10中启用剩余时间电池寿命指示器
- 一个小型嵌入式操作系统设计:精髓都有了
- 详解Windows如何获取某个文件正在被哪个进程调用方法
- windows-server-2008 – 如何将SQL Server 2008服务器链接到
