验证oracle安装成功用plsql登录oracle时提示TNS协议适配器错误,用了网上说的三种方法后还是同样问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了验证oracle安装成功用plsql登录oracle时提示TNS协议适配器错误,用了网上说的三种方法后还是同样问题相关的知识,希望对你有一定的参考价值。

TNS: 协议适配器错误的问题的原因有三个:
1.监听服务没有起起来。windows平台个一如下操作:开始---程序---管理工具---服务,打开服务面板,启动oraclehome92TNSlistener服务。
2.database instance没有起起来。windows平台如下操作:开始---程序---管理工具---服务,打开服务面板,启动oracleserviceXXXX,XXXX就是你的database SID.
3.注册表问题。regedit,然后进入HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0将该环境变量ORACLE_SID设置为XXXX,XXXX就是你的database SID.或者右几我的电脑,属性--高级--环境变量---系统变量--新建,变量名=oracle_sid,变量值=XXXX,XXXX就是你的database SID.或者进入sqlplus前,在command line下输set oracle_sid=XXXX,XXXX就是你的database SID.
经过以上步骤,就可以解决问题

1、ORA-12541:TNS:没有监听器
  原因:没有启动监听器或者监听器损坏。如果是前者,使用命令net startOracleOraHome81TNSListener(名字可能有出入)即可;如果是后者,则使用“Net8Configuration

Assistant”工具向导之“监听程序配置”增加一个监听器即可(基本不用写任何信息,一路OK。在添加之前可能需要把所有的监听器先删除!)
2、ORA-12500:TNS:监听程序无法启动专用服务器进程或ORA-12560:TNS:协议适配器错误
  原因:ORACLE的数据库服务没有启动。使用命令net start ORACLESERVICEORADB(ORADB为数据库名字)即可。如果仍没有解决,请继续向下看。

3、如果数据库服务启动失败,则很有可能是其注册表项值损坏,最好的做法是以下两步:
  1)ORADIM -DELETE -SID oradb 删除数据库服务项
  2)ORADIM -NEW -SID oradb 新增数据库服务项
  注:这个过程中如果出错,就重启计算机!
4、ORA-12154:TNS:能解析服务名
  原因:ORACLE的网络服务名没有正确配置。请使用“Net8 ConfigurationAssistant”工具向导之“本地网络服务名配置”配置TNS即可。如果仍没有解决,请继续向下看。
5、ORA-1034 :TNS:ORACLE不可用
  原因:ORACLE的数据库服务正确启动,但是数据库没有打开!
  使用命令:
  1)svrmgrl 启动服务管理器
  2)connect internal 以internal身份登陆
  3)startup 打开数据库
6、ORA-12560:TNS:协议适配器错误(顽固性的)
  原因:未知。
  解决:必杀技--打开“Windows任务管理器”,杀死ORACLE.exe及ORADIM.exe进程,书写自己的

ora_startup.bat,执行之!追问

我说的ORACLE错误是ORA-12560前面说的三种方法我已经试过了,不能解决,你说的第6点,能详细点说明么,怎样书写自己的ora-startup.bat

追答

这两个服务要启动
OracleOraDb10g_home1TNSListener
OracleServiceORCL
c:\WINDOWS\system32\drivers\etc
下host文件加
ip 主机名

参考技术A 1.安装成功了,你有创建数据库吗?
2.如果有创建数据库,有没有改过机器名?
3.不是上面的两个问题,确认侦听器服务启动了吗?
4.数据库服务启动了吗?追问

1.控制面板里面的服务有个oracleseviceorac 我已经启动,这个应该是创建数据库了吧
2.机器名??为何更改,我没改过
3.侦听器服务是服务里面的lister那个服务吧,我已经启动了
4.在服务里面的oracle我都已经启动了

追答

说机器名,是因为oracle的侦听器文件里记录这个,如果改了会出这个问题,没改过。不跳过这个。

那你连接出错的错误码是什么,ora-xxxxx这个形式的。贴出来看看。

追问

ora-12560协议适配器错误

追答

帮你找了一下,多数都和1楼复制的一样。

如果你确认所有的oracle服务都启动了并没有错误,那就考虑一下防火墙吧。是不是1521这个端口不能穿过防火墙。

再想想安装的时候有没有出过错误。
你所说的plsql 是不是plsqldev
你试着用sqlplus登陆看是不是正常。

追问

我登陆的是plsqldev,我输入控制台登录地址http: pz:1158/em;验证oracle是正常登陆的,sqlplus里面的主机字符串应该填什么啊

追答

你的服务是这个oracleseviceorac
应该是orac

追问

呵呵 好谢谢你 我晚上回去在试下

追答

不客气,嗯,看你写的em
我想起来一点,好象em是单独存在的,可以关联一个数据库,也可以不关连。你em好用,并不一定是有数据库了。这个只在以前学9i的时候试过,具体没用过。
所以也说不清,

如果你确认oracle安装的没有问题,可以用oracle中的工具再创建一个数据库,别用orac这个名,试试,然后连那个数据库。

本回答被提问者采纳
参考技术B 有没有配置本地net服务名呀,
用了哪三种方法,请尽量说明白
参考技术C 你没有设置oracle 网络吧!
参考技术D 数据库是否正常启动,监听是否正常?追问

怎样判断数据库正常启动,监听是否正常??
我输入控制台登录地址http: pz:1158/em;验证oracle是正常登陆的

以上是关于验证oracle安装成功用plsql登录oracle时提示TNS协议适配器错误,用了网上说的三种方法后还是同样问题的主要内容,如果未能解决你的问题,请参考以下文章

oracle用sql plus登陆不了,但是用pl sql可以登录,是啥原因?

安装oracle和PLSQL的经历

Oracle11g 默认用户帐号和密码 解锁用户 plsql登录

不装oracle plsql怎么用

plsql登录提示oci.dll版本错误,oracle32位客户端和plsql配套问题

plsql developer 12 怎么免安装oracle