【ORACLE】 ORA-12514:TNS监听程序当前无法识别连接描述符中请求的服务解决

使用PL/SQL Developer 连接数据库时出现ORA-12514:TNS监听程序当前无法识别连接描述符中请求的服务,此时Oracle主服务和监听器服务是已经启动的。

虽然后面重启后又自动连接上了,在这里记录一下这个错误以及搜索到的大佬给的解决办法。


指路大佬的原文博客:https://www.cnblogs.com/Liang-Haishan216/p/6474528.html

这个也可以参考:http://www.blogjava.net/freeman1984/archive/2011/04/15/348350.html


<转载>:

解决:

打开H:\Oracle\product\11.2.0\dbhome_1\NETWORK\ADMIN(不同机器目录可能不同)目录下的listener.ora文件,发现此文件内容如下:

  1. #listener.ora Network Configuration File:  
  2. H:\Oracle\product\11.2.0\dbhome_1\network\admin\listener.ora  
  3. #Generated by Oracle configuration tools.  
  4.    
  5. SID_LIST_LISTENER=  
  6.   (SID_LIST =  
  7.     (SID_DESC =  
  8.       (SID_NAME = CLRExtProc)  
  9.       (ORACLE_HOME =H:\Oracle\product\11.2.0\dbhome_1)  
  10.       (PROGRAM = extproc)  
  11.       (ENVS ="EXTPROC_DLLS=ONLY:H:\Oracle\product\11.2.0\dbhome_1\bin\oraclr11.dll")  
  12.     )  
  13.   )  
  14.    
  15. LISTENER=  
  16.   (DESCRIPTION_LIST =  
  17.     (DESCRIPTION =  
  18.       (ADDRESS = (PROTOCOL = IPC)(KEY =EXTPROC1521))  
  19.       (ADDRESS = (PROTOCOL = TCP)(HOST =localhost)(PORT = 1521))  
  20.     )  
  21.   )  
  22.    
  23. ADR_BASE_LISTENER= H:\Oracle  

修改成如下内容(注意红色部分的内容):

#listener.ora Network Configuration File:

H:\Oracle\product\11.2.0\dbhome_1\network\admin\listener.ora

#Generated by Oracle configuration tools.

SID_LIST_LISTENER=

  (SID_LIST =

         (SID_DESC =

      (GLOBAL_DBNAME = ORCL)

      (ORACLE_HOME =H:\Oracle\product\11.2.0\dbhome_1)

      (SID_NAME = ORCL)

    )

    (SID_DESC =

      (SID_NAME = CLRExtProc)

      (ORACLE_HOME = H:\Oracle\product\11.2.0\dbhome_1)

      (PROGRAM = extproc)

      (ENVS ="EXTPROC_DLLS=ONLY:H:\Oracle\product\11.2.0\dbhome_1\bin\oraclr11.dll")

    )

  )

LISTENER=

  (DESCRIPTION_LIST =

    (DESCRIPTION =

      (ADDRESS = (PROTOCOL = IPC)(KEY =EXTPROC1521))

      (ADDRESS = (PROTOCOL = TCP)(HOST =localhost)(PORT = 1521))

    )

  )

ADR_BASE_LISTENER= H:\Oracle

说明:每台电脑的Oracle安装目录和实例名不尽相同,修改此文件的ORACLE_HOME(本机Oracle安装目录)和SID_NAME应该按照你自己的设置。



### 解决 Oracle 19c 中 ORA-12514 错误的方法 当遇到 `ORA-12514` 错误时,通常意味着 TNS 监听器未能找到与连接描述符匹配的服务名称。这可能是由于配置文件中的设置不正确或监听器未正确注册服务。 #### 检查并修改 `listener.ora` 确保 `listener.ora` 文件中定义了正确的监听地址和服务名称。此文件位于 Oracle 安装目录下网络配置文件夹中。对于某些工具如 Navicat,可能会读取解压目录而非安装目录下的 `listener.ora`[^2]: ```plaintext LISTENER = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = your_host_name_or_ip)(PORT = 1521)) ) ) SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = orclpdb) (ORACLE_HOME = /path/to/oracle_home) (SID_NAME = orcl) ) ) ``` #### 修改 `tnsnames.ora` 同样重要的是确认 `tnsnames.ora` 的内容指向有效的数据库实例和服务名。该文件也应放置于相同的路径下,并且应当包含如下条目来指定目标数据库的连接字符串[^4]: ```plaintext ORCLPDB = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = your_host_name_or_ip)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orclpdb.your_domain.com) ) ) ``` #### 验证服务状态并重启监听器 完成上述更改后,验证监听器的状态以及它是否已成功加载新的配置。如果必要的话,在 Windows 上可以通过任务管理器内的服务选项卡停止再启动名为 `Oracle<sid>_Listener` 的进程;而在 Linux/Unix 平台上则通过命令行执行相应操作[^3]。 #### 使用 PL/SQL 开发者或其他客户端测试连接 最后一步是在应用程序或者像 PL/SQL Developer 这样的专用 IDE 中尝试建立到数据库的新会话,以检验问题是否得到解决[^1]。 ```python import cx_Oracle connection = None try: connection = cx_Oracle.connect( user="your_username", password="your_password", dsn="localhost:1521/ORCLPDB" ) except Exception as e: print(e) if connection is not None: cursor = connection.cursor() cursor.execute('SELECT * FROM dual') result = cursor.fetchone() print(result) cursor.close() connection.close() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值