Oracle导dmp出现文件ORA-12154: TNS: 无法解析指定的连接标识符问题的解决方案_oracle_脚本之家

其实TNS无法解析是Oracle操作里经常遇到的问题,原因有二:

配置好rac后,两个节点用tnsping都可以ping通,但用sqlplus连接都出现以下错误,不知道哪里出了问题[oracle@rac2
admin]$ lsnrctl statusLSNRCTL for Linux: Version 9.2.0.4.0 – Production
on 04-MAR-2008 08:32:26Copyright 1991, 2002, Oracle Corporation. All
rights reserved.Connecting to (DESCRIPTION=(ADDRESS=))STATUS of the
LISTENER————————Alias LISTENERVersion TNSLSNR for Linux:
Version 9.2.0.4.0 – ProductionStart Date 04-MAR-2008 08:29:03Uptime 0
days 0 hr. 3 min. 22 secTrace Level offSecurity OFFSNMP OFFListener
Parameter File /home/oracle/9.2.0.4/network/admin/listener.oraListener
Log File /home/oracle/9.2.0.4/network/log/listener.logListening
Endpoints Summary… (DESCRIPTION=(ADDRESS=))Services Summary…Service
“PLSExtProc” has 1 instance. Instance “PLSExtProc”, status UNKNOWN, has
1 handler for this service…Service “esal” has 2 instance. Instance
“rac1”, status READY, has 1 handler for this service… Instance “rac2”,
status READY, has 1 handler for this service…The command completed
successfully[oracle@rac2 admin]$ lsnrctl serviceLSNRCTL for Linux:
Version 9.2.0.4.0 – Production on 04-MAR-2008 08:32:32Copyright 1991,
2002, Oracle Corporation. All rights reserved.Connecting to
(DESCRIPTION=(ADDRESS=))Services Summary…Service “PLSExtProc” has 1
instance. Instance “PLSExtProc”, status UNKNOWN, has 1 handler for this
service… Handler: “DEDICATED” established:0 refused:0 LOCAL
SERVERService “esal” has 2 instance. Instance “rac1”, status READY, has
1 handler for this service… Handler: “DEDICATED” established:0
refused:0 state:ready REMOTE SERVER (address=) Instance “rac2”, status
READY, has 1 handler for this service… Handler: “DEDICATED”
established:0 refused:0 state:ready LOCAL SERVERThe command completed
successfully[oracle@rac2 admin]$ sqlplus cy/zh@esalSQL*Plus: Release
9.2.0.4.0 – Production on Tue Mar 4 08:32:45 2008Copyright 1982, 2002,
Oracle Corporation. All rights reserved.ERROR:ORA-12154: TNS:could not
resolve service name

首先说明dmp文件:

Oracle服务器没有装好(一般不建议重装,因为Oracle卸载不完全是没法重装的)

Enter user-name: ERROR:ORA-01017: invalid username/password; logon
denied

Oracle备份文件是以dmp结尾,这种文件是oracle的逻辑备份文件,常用于数据库逻辑备份,数据库迁移等操作。

现在本文给出解决方案:

Enter user-name: cy/zh@rac1ERROR:ORA-12154: TNS:could not resolve
service name

 

现在先测试一下tns是否可以ping,成功的界面大致如下

SP2-0157: unable to CONNECT to ORACLE after 3 attempts, exiting
SQL*Plus[oracle@rac2 admin]$ sqlplus cy/zh@rac2SQL*Plus: Release
9.2.0.4.0 – Production on Tue Mar 4 08:32:59 2008Copyright 1982, 2002,
Oracle Corporation. All rights reserved.ERROR:ORA-12154: TNS:could not
resolve service name

一.Oracle导入备份文件步骤:我用的是Oracle 11g版本

在oracle安装路径的tns配置文件里添加如下代码

Enter user-name:

1.把数据库的备份文件:xx.DMP  拷贝到oracle安装目录下的dpdump文件夹中,

# tnsnames.ora Network Configuration File: d:\Oracle\product\10.2.0\client_1\NETWORK\ADMIN\tnsnames.ora# Generated by Oracle configuration tools.ORCL = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS =  (CONNECT_DATA =  ) )

按照如下过程,一般都能解决:在虚拟机内开cmd,用lsnrctl
status查看监听器监听的服务
如看到监听服务“orcl”,那在本机的tns配置中必须写orcl;如果想要自定义,则在虚拟机内的listener配置中就要加入自定义服务名,记得要重启监听服务:lsnrctl
reload 最后形成的配置文件如下 虚拟机listener:

比如我的路径是: D:\work\app\admin\orcl\dpdump 

其中orcl是我的数据库名称,这个需要根据需要配置

SID_LIST_LISTENER = (SID_LIST = (SID_DESC =  自定义服务名 (ORACLE_HOME = E:oracleproduct10.2.0db_1) db_home  (SID_DESC =  (SID_NAME = PLSExtProc) (ORACLE_HOME = E:oracleproduct10.2.0db_1) ##这个服务保证你可以使用外部过程,如C程序 ) )

ORCL_XNJ = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS =  (CONNECT_DATA =  与自定义服务名对应 ) )

 

D:\oracle\product\11.2.0\dbhome_1\NETWORK\ADMIN

再次连接,问题解决!记住,一定从最简单的原因找起,不要一上去就看到网上的什么改process数、注册表之类的,要想想本机能连为什么通过网络就不行,还是定位问题。VS2008连接oracle
出现错误 ora-12154 tns 无法解析指定的连接标示符

在你的PLSQL Developer中 或者直接在cmd下登录sqlplus,  作如下操作:步骤2-4

补充:下面给出Oracle数据库还原的步骤示例

在保证你的代码没有错误的前提下:检查OracleOraDb10g_home1TNSListener
服务有没有启动,即监听服务检查tnsnames.ora是否添加连接串,其路径一般是:%Oracle_home%product10.2.0db_1NETWORKADMINtnsnames.ora

2.创建表空间 tablespace_name.dbf 

1、将TESTDB.bmp放置在dpdump目录,如下路径:

其它网友的补充:

create tablespace  tablespace_name  datafile
‘D:\work\app\admin\orcl\dpdump\tablespace_name.dbf’ size 500m 
reuse autoextend on next 10m maxsize unlimited extent management local
autoallocate permanent online;

E:\app\Administrator\admin\orcl\dpdump

今天装oracle安装都完成了,但出现了“ORA-12154
TNS”的错误,最开始以为是oracle安装处了问题,但后来发现并不是,因为用SQL
Plus可以登录,只是用plsql登录时才出现这错,用360完全卸载了qlsql后,从新装了次,还是那错,郁闷。。。后来又把数据库删掉重新建立,还是不行,整了半天,最后自己都整晕了,算了,重头再来吧。。。百度下很多安装图解,按着来就成

— 指定表空间初始大小为500M,并且指定表空间满后每次增加的大小为10M。

create user testdb65 identified by “testdb65” default tablespace users temporary tablespace temp;

grant connect,dba to testdb65;

CREATE TABLESPACE NNC_DATA01 DATAFILE ‘D:\tablespace\nnc_data01.dbf' SIZE 500M AUTOEXTEND ON NEXT 50M EXTENT MANAGEMENT LOCAL UNIFORM SIZE 256K ; CREATE TABLESPACE NNC_INDEX01 DATAFILE ‘D:\tablespace\nnc_index01.dbf' SIZE 100M AUTOEXTEND ON NEXT 50M EXTENT MANAGEMENT LOCAL UNIFORM SIZE 256K ;

oracle服务端安装图解//www.jb51.net/article/108555.htmoracle客户端安装图解//www.jb51.net/article/108556.htm

 

4、导入 bgyhr2是来源库

oracle完全卸载//www.jb51.net/article/96395.htm或者直接在注册表中按F3搜索oracle,删除注册文件,不过貌似文件有点多,操作有点慢,建议用上边链接的方法

3.创建用户

impdp testdb65/testdb65@orcl schemas=testdb65 dumpfile=TESTDB65.dmp impdp ncjob65/ncjob65@orcl schemas=testdb65 dumpfile=TESTDB65.dmp

总结了下要注意的几点

create user +用户名+ identified by +密码+ default tablespace +表空间名;
 

导出 scott 是要导出的库

1.安装服务端是一般选“基本安装”就行2.使用PLSQL Developer时,“ORA-12154
TNS无法解析指定的连接标识符”的问题安装时报后边的错“warning some oracle
net versions cannot connect from a path with
parentheses”,这错原来提示了,不能有括号,修改了安装路径就没有问题了相应的上边的“ORA-12154
TNS无法解析指定的连接标识符”错也没啦,有点晕,没整明白,但确实好啦3.“ORA-12154
TNS无法解析指定的连接标识符”按照网上的方法有两种,但我试了,在我这都不好使,下边贴出来,没准儿啥时候可以用1.解决办法,修改PLSQL
Developer的选项设置:客户端、服务器端Oracle软件装好之后,用PLSQL
Devloper登录时,点击取消,进入PLSQL
Developer主界面,菜单Tools-Preferences,在设置窗口中,选择Oracle-Connection,对应设置窗口中,找到Oracle
Home,选择OraDb10g_home1,保存设置,重新登录PLSQL Developer即可

–用户、密码指定表空间

expdp lfwtrain/a@orcl schemas=当前用户 dumpfile=expdptest.dmp

2.修改D:\oracle\product\10.2.0\db_1\NETWORK\ADMIN路径下的tnsnames.ora文件######
一般的配置
##################################

 

以上所述是小编给大家介绍的Oracle导dmp出现文件ORA-12154: TNS:
无法解析指定的连接标识符问题的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

ORALOCAL = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS =  (CONNECT_DATA =  (SERVICE_NAME = oralocal) ) )

4.给用户授权

grant connect,resource,dba to user_name;

— 给用户user_name 授权。

connect和resource是两个系统内置的角色,和dba是并列的关系。