6

有什么方法可以在不安装 oracle 客户端或使用 tnsname 的情况下连接到 Oracle DB?应用程序需要部署在客户端机器上,因此希望它是独立的。

4

1 回答 1

3

为了澄清我的评论,这可以通过 Oracle 的 Managed ODP.net 实现,它不需要客户端计算机安装任何 Oracle 客户端/驱动程序。它非常适合您无法控制安装在目标机器上的软件的 Windows 或控制台应用程序。

要下载托管客户端,您可以使用库包管理器 ( https://www.nuget.org/packages/odp.net.managed/ ) 从 nuget 获取它:

PM> Install-Package odp.net.managed

关于 TNSnames(因为这也是一个客户端依赖项),如果您使用 Oracle 的 EZ Connect,您可以完全绕过 TNSnames。为此,您只需将数据源格式化为server-name:port/sid. 实际上,自从 TNSnames 可用以来,我就完全停止使用它了。

以下是如何使用 Managed ODP.net 执行此操作的示例:

OracleConnectionStringBuilder sb = new OracleConnectionStringBuilder();
sb.DataSource = "MyOracle.MyCompany.com:1521/MySid"; // EZ Connect -- no TNS Names!
sb.UserID = "luke";
sb.Password = "Jedi4Eva";

OracleConnection conn = new OracleConnection(sb.ToString());
conn.Open();

OracleCommand cmd = new OracleCommand("select * from dual", conn);
object o = cmd.ExecuteScalar();

conn.Close();
于 2015-11-04T17:15:53.143 回答