ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务,是设置错误造成的,解决方法如下:
1、首先,先来了解一下这个数据库文件,在电脑上这个文件里存放的就是配置数据,监听器在启动时会读取该文件。
2、接下来,要知道SID_LIST_LISTENER参数就是数据库注册,动态注册或是静态注册。
3、然后,如果因为动态注册引起的问题,那么最简单的解决方法,是由动态注册改为静态注册。
4、最后,SID_NAME参数是数据库实例名,GLOBAL_DBNAME参数是全局数据库名。
5、配置好后,重启监听器,就可正常连接了。
ora-12514的错误的原因有很多,但无外乎这几种:
1.ora-12514: TNS: 没有监听器
显而易见,服务器端的监听器没有启动,另外检查客户端IP地址或端口填写是否正确。启动监听器:
$ lsnrctl start或C:lsnrctl start
2、ora-12514: TNS: 无法处理服务名
检查输入的服务名与配置的服务名是否一致。另外注意生成的本地服务名文件(Windows下如D:oracleora92networkadmin tnsnames.ora,Linux/Unix下/network/admin/tnsnames.ora)里每项服务的首行服务名称前不能有空格。
3、ora-12514: TNS: 监听进程不能解析在连接描述符中给出的SERVICE_NAME
打开NetManager,选中服务名称,检查服务标识栏里的服务名输入是否正确。该服务名必须与服务器端监听器配置的全局数据库名一致。同时检查sqlnet.ora,例如如果想要采用简便连接方式连接就需要在NAMES.DIRECTORY_PATH参数中添加EZCONNECT。
拓展知识:
ora-12514:TNS:监听程序当前无法识别链接描述符中请求的服务
该问题是由于缺少监听器的SID_LIST描述项引起的,采用netca进行配置的时候经常会遇到该问题,listener.ora示例如下
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /opt/oracle/product/9.2.0.4)
(PROGRAM = extproc))
(SID_DESC =
(GLOBAL_DBNAME = SAMPLE.COM)
(ORACLE_HOME = /opt/oracle/product/9.2.0.4)
SID_NAME = SAMPLE)))LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = tcy.com)(PORT = 1521)))
oracle 11g ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务是设置错误造成的,解决方法为:
1、找到ORACLE数据库安装目录,product\11.2.0\dbhome_1\NETWORK\ADMIN 下的listener.ora文件。
2、右键点击该文件,选择【属性】选项,点击打开。
3、进入属性界面,点击上方【安全】。
4、进入安全界面,选择当前登录用户,点击【编辑】。
5、在下方的权限处,勾选【完全控制】,点击进行保存。
6、此时用记事本打开listener.ora文件,将SID名称设置为ORCL点击保存。
7、然后进入服务列表,重启oracleserviceorcl服务即可,问题解决。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)