0

从 C# 我使用 OleDb 连接到 Oracle,执行以下操作:

String connectionString = "Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=x;Password=y;Data Source=z";

var connection = new System.Data.OleDbConnection(connectionString);
connection.Open();

这很好用。

在同一个过程中,我尝试使用托管驱动程序进行连接,执行以下操作:

String connectionString = "USER ID=x;PASSWORD=y;DATA SOURCE=z";

var connection = new Oracle.ManagedDataAccess.Client.OracleConnection(connectionString);
connection.Open();

失败并出现以下错误:

Oracle.ManagedDataAccess.Client.OracleException (0x80004005): ORA-12154: TNS:could not resolve the connect identifier specified ---> OracleInternal.Network.NetworkException (0x00002F7A): ORA-12154: TNS:could not resolve the connect identifier specified
   at OracleInternal.Network.AddressResolution..ctor(String TNSAlias, String instanceName)
   at OracleInternal.Network.OracleCommunication.DoConnect(String tnsDescriptor)
   at OracleInternal.ServiceObjects.OracleConnectionImpl.Connect(ConnectionString cs, Boolean bOpenEndUserSession, String instanceName)

Server stack trace: 
   at OracleInternal.ConnectionPool.PoolManager`3.Get(ConnectionString csWithDiffOrNewPwd, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch)
   at OracleInternal.ConnectionPool.OraclePoolManager.Get(ConnectionString csWithNewPassword, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch)
   at OracleInternal.ConnectionPool.OracleConnectionDispenser`3.Get(ConnectionString cs, PM conPM, ConnectionString pmCS, SecureString securedPassword, SecureString securedProxyPassword)
   at Oracle.ManagedDataAccess.Client.OracleConnection.Open()

过去,当 tnsnames 出现问题时,我收到过类似的错误,但我从未遇到过 OleDb 在托管驱动程序不工作时工作的情况。

我仔细检查了两个连接字符串中的用户、密码和数据源是相同的。

4

2 回答 2

0

听起来您的 TNSNames 设置不正确。您也可以使用 tnsnames 执行这样的连接字符串

static string constr = @"Data Source=(DESCRIPTION=
         (ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=yourhostname )(PORT=1521)))
         (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=XE)));
        User Id=system ;Password=yourpasswrd"; 

这是错误 ORA-12154:TNS:无法解析指定的连接标识符?

于 2016-04-13T17:26:34.227 回答
0

ODP.NET 托管驱动程序使用不同的方式查找tnsnames.ora,resp。sqlnet.ora比 OraOLEDB 做得更好。

例如,OraOLEDB 读取注册表以获取TNS_ADMIN值,而 ODP.NET 托管驱动程序则不会。有关详细信息,请参阅确定相关 tnsnames.ora 文件的位置。

一种解决方案是设置一个环境变量TNS_ADMIN,其中包含文件夹名称tnsnames.orasqlnet.ora文件所在的位置。据我所知,环境变量(几乎)优先于 ODP.NET 托管驱动程序和 OraOLEDB 中的所有其他设置。

于 2016-04-14T09:32:48.583 回答