Oracle 连接问题 ORA-12154: TNS: 无法解析指定的连接标识符(来源:Internet)

本文解决了一个常见的Oracle数据库连接问题“ORA-12154:TNS:无法解析指定的连接标识符”。介绍了如何通过修改注册表、卸载并重新配置Oracle Developer Tools来解决该问题。

前几天,同事装上oracle的客户端,在ASP.Net下面怎么连都连不到oracle数据库(操作系统是XP,报错找不到OIC.DLL,之前我也遇到过,重装了一下客户端就好了,我用的是2000 professional的系统)。

后来我到Oracle官方网站上寻找解决方案,下载了Oracle Developer Tools for Visual Studio .NET 10.1.0.4.0 (ODT for VS.Net),把它装上之后,可以在.net中浏览oracle数据库,估计可以浏览oracle数据库了,应该可以操作oracle数据库,鼓吹通事把ODT for VS.Net装上之后,果然他的机器上的ASP.Net程序可以正常连接oracle了,就是这个问题,昨天装了整整一天的系统。

    今天上午他的问题刚刚解决,下午我这边就出了问题,连接oracle时报错,信息如下"ORA-12154: TNS: 无法解析指定的连接标识符", 到google上到处搜,看到一些英文的网站的答案是修改tnsname.ora就可以修复连接。检查了一下也没发现这个文件的问题。

    估计是安装ODT for VS.Net之后,OracleHome和OracleSID有重复或者无效, 到注册表中一看,果然是有问题,发现HKey_LocalMachine/Software/Oracle下面的Oracle_Home路径被改成了E:/program files, 我的oracle是装在E:/oracle目录的,于是把这个改了,再试,系统也重起了,依然无效,后来想干脆把ODT 给删了,于是到控制面板找Oracle Developer Tools, 怎么都找不到,到是找到了ODP for .Net,把这个给卸载了,以前装的Oracle Developer Tools目录(E:/Oracle/product/10.1.0/Client_1)依然没有被删除,于是手动删除这个目录,提示OCI.dll正在使用,无法删除,再尝试把这个目录给重命名了,居然命名成功。于是重启系统,再运行Asp.Net的客户端,成功连接Oracle数据库。

    总结一下,装了解决Oracle Developer Tools之后,出现“ORA-12154: TNS: 无法解析指定的连接标识符”报错的解决方法如下:

    1.检查注册表,HKey_LocalMachine/Software/Oracle下面的Oracle_Home,若不对,修改成正确的;

    2.卸载ODP for .Net (或者卸载ODT for .Net, ODT中包含ODP, ODT 是VS.Net的一个集成插件,用于连接和浏览oracle数据库,并且提供对oracle数据库的拖拽操作,类似VS.Net对于SQL Server的资源管理器);

    3.如果ODT for .Net的目录依然存在,删除或者重命名此目录;

    然后重起系统,重新连接ASP.Net程序,如果还有同样的错误,看着办吧,我建议重装Oracle吧。

    分析原因:系统原来装的是ORACLE 10G 10.1.0,卸载后还没重启就装上10.2.0,结果先是监听器起不来,竟然还是指向10.1.0的位置,监听器当然不能启动了。

    处理过程:
    1、查找注册表,将监听器指向新的位置,重启服务,OK;
    2、PL/SQL DEVELOPER还是连接不了,其它方式都正常。将原先安装在其它逻辑盘的ODP for .Net 卸载重装到与ORACLE 10.2.0同一位置。重启系统,DEVELOPER还是报错,不过些时报错提示信息为空。
    3、因为DEVELOPER设置有更改后,进入菜单TOOLS》PREFERENCES...设置,在ORACLE下的CONNECTION中,将ORACLE HOME和OCI LIBIARY设为空即自动检测。连接正常,问题解决。

    二、应用程序中报错:

    一个很难想到的引起ORA-12154的原因
        使用OracleClient.OracleConnection时(我连的是Oracle 9i,其他版本未知),如果你的执行目录太长或者有括号等(未考察有些什么符号),那么即使你的服务名是对的,也会引起ORA-12154问题“TNS: 无法处理服务名”,当出现这个问题时,请也考虑这个原因。

### ### 原因分析 IMP-00058 错误通常伴随着 ORA-12154,表示 `imp` 工具无法解析连接字符串中的服务名或 TNS 别名。此错误的根本原因在于 Oracle 无法识别 `@` 后面指定连接标识符(如 `SID` 或 `SERVICE_NAME`),这可能是由于 TNS 配置缺失、拼写错误或环境变量未正确设置所致。 例如,在执行如下命令时: ```bash imp test/test@SID full=y file=d:\data\GSCLOUD_01.dmp ignore=y ``` 如果 `SID` 没有在 `tnsnames.ora` 中定义,则会报错 ORA-12154[^1]。 --- ### ### 解决方法 #### 确保使用有效的服务名或完整 TNS 描述 应确保 `@` 后面的连接标识符是有效的 TNS 名称,或者直接使用完整的 TNS 描述方式: ```bash imp test/test@(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=orcl))) file=d:\data\GSCLOUD_01.dmp full=y ignore=y ``` 该方式绕过 `tnsnames.ora` 的依赖,适用于临时测试或配置受限的环境[^1]。 --- #### 检查 tnsnames.ora 文件配置 Oracle 客户端通过 `$ORACLE_HOME/network/admin/tnsnames.ora` 文件解析连接别名。确保目标服务名(如 `orcl`)已在该文件中正确定义,示例格式如下: ```plaintext ORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl) ) ) ``` 若文件中不存在对应条目,则需手动添加或修改现有条目[^2]。 --- #### 使用 tnsping 测试连接有效性 在命令行中运行 `tnsping` 可验证连接标识符是否被正确解析: ```bash tnsping orcl ``` 如果输出显示成功解析并尝试连接,则说明 TNS 配置无误;否则需检查网络配置和监听器状态[^2]。 --- #### 设置环境变量与 Oracle 网络配置 确认以下环境变量已正确设置: - `ORACLE_HOME`:指向 Oracle 客户端或数据库安装目录。 - `TNS_ADMIN`(可选):指定 `tnsnames.ora` 所在路径,若未设置则默认查找 `$ORACLE_HOME/network/admin`。 若上述变量未设置,可能导致 Oracle 工具无法定位配置文件[^3]。 --- #### 替代方案:使用数据泵 impdp/expdp 对于 Oracle 12c 及以上版本,建议使用 `Data Pump` 工具替代传统 `imp/exp`。其优势包括更高的性能、更好的错误处理能力以及支持并行操作等。 例如,使用 `impdp` 导入: ```bash impdp system/password@orcl directory=DATA_PUMP_DIR dumpfile=GSCLOUD_01.dmp full=y ``` 其中 `directory` 参数需预先在数据库中创建,并指向实际文件存储路径[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值