不敢相信我不得不问这个问题,但我终生无法连接到 Oracle 11g 数据库。
以下在使用时有效System.Data.OracleClient
- 但显然这是贬值了。使用完全相同的代码但使用Oracle.DataAccess.OracleClient
时出现以下错误
{"ORA-12545: Connect failed because target host or object does not exist"}
这是我的代码
using (OracleConnection con = new OracleConnection("Data Source=orac;User Id=SYSTEM; Password=Pass;"))
{
con.Open();
Console.WriteLine("Connection opened");
OracleCommand cmd2 = new OracleCommand("SELECT * FROM SYSTEM.TABLE", con);
OracleDataReader oracleDataReader = cmd2.ExecuteReader();
while (oracleDataReader.Read())
{
Console.WriteLine(oracleDataReader[0]);
}
}
谁能帮我解决我做错了什么?
我必须将程序更改为 32 位Oracle.DataAccess.dll
才能加载。
这甚至是要使用的正确库吗???
谢谢
编辑
tnsnames.ora 文件如下:
# tnsnames.ora Network Configuration File:
C:\app\UserName\product\11.2.0\dbhome_3\network\admin\tnsnames.ora
# Generated by Oracle configuration tools.
ORAC =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1522))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orac.example.com)
)
)
LISTENER_ORAC =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1522))
更新
我曾尝试使用 Oracle Sql 开发人员进行连接。只要我使用 TNS 连接类型,它就可以工作,但如果我使用 Basic 连接类型,它就不起作用。
我还注意到在我的服务中有 2 个调用
OracleOraDb11g_home1TNSListener OracleOraDb11g_home2TNSListener
我相信 orac dbhome 是 home3,这可能是问题吗?如果是这样,有人知道我将如何修复它吗?
谢谢
更新 在 HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ 中有两个属性(默认)和 inst_loc。有几个文件夹,其中两个名为“KEY_OraDb11g_home1”和“KEY_OraDb11g_home2”,它们都包含一个名为 ORACLE_HOME 的属性,它们是:
KEY_OraDb11g_home1 - ORACLE_HOME = C:\app\UserName\product\11.2.0\dbhome_2 KEY_OraDb11g_home2 - ORACLE_HOME = C:\app\UserName\product\11.2.0\dbhome_3
home1 中 Db 的 SID 称为 OracleDev,我可能很久以前就安装了它,但如果它导致问题,我现在肯定不需要它
谢谢