Oracle-12514错误发生的几种原因
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)))
tnsnames.ora 文件中没有配置指定的 服务名,你把tnsnames.ora 文件内容贴出来,还有你红色的可以使用其他东西代替,让我们看到。这样有助于解决问题。
LISDB = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.22.141)(PORT = 1521)) ) (CONNECT_DATA = (SID = lisdb) ) ) 要不行,把tnsnames.ora删掉,用Configuration Assistant重新建 还不行啊,你确定lisdb是正确的。
拓展资料:
TNS listner里面的数据库SID和数据库配置不一致导致的 到数据库服务器上,找到listner.ora,文本打开,形如 SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = SID(ORACLE_HOME = C:\oracle\product\10.2.0\db_1) ) 检查里面的SID.查看你现在虚拟机中的端口,windows中使用的命令是: netstat -an,打开Net Manager。