plsql以前能正常连ORACLE数据库,但突然断电重启后就报错ORA-12514,不是listener.ora配置文件的问题

本文针对ORA-12514及ORA-00322等错误进行详细解析,介绍了如何排查并修复Oracle数据库连接问题,包括检查环境变量、启动状态、日志文件等步骤。

昨天通过plsql能正常连接oracle数据库,但电脑突然关机之后,再连接就报错:
ORA-12514:TNS:监听程序当前无法识别连接描述符中请求的服务。

1、首先排除了服务是否启动的问题,因为实例和监听都已启动。
2、然后百度上都说是listener.ora配置文件的问题,但是想想应该不是,因为以前都可以用的。

3、然后去看看能不能通过cmd连接oracle数据库,
在cmd中输入: sqlplus sys/这里输入密码 as sysdba
在这里插入图片描述
如果报错:
ORA-12560: TNS: 协议适配器错误.
可以先看看是不是环境变量path顺序的问题:把D:\app\24457\product\11.2.0\dbhome_1\bin 上移到D:\app\24457\product\11.2.0\client_1\bin 上面来,如下图
在这里插入图片描述
如果还没解决,看看是不是服务器没启动的原因

4、解决了cmd连接oracle数据库的问题,那就去看一下oracle的日志(alert_orcl.log)
日志路径通过下面语法查询:
select * from v$diag_info where name =‘Diag Trace’;
在这里插入图片描述
一般日志名称是: alter_xxxx.log (xxxx就是实例名称,本地是orcl)

5、查看日志后发现不是监听的问题,也不是listener.ora配置文件的问题。而是
ORA-00322,
ORA-00312:online log 2 thread 1: ‘/opt/oracle/orcl/redo02.log

按步骤执行下面的语法,3里面的路径要与ORA-00312错误里面的一样
1、 shutdown immediate;
2、 startup mount;
3、 alter database clear logfile ‘opt\oracle\orcl\REDO02.LOG’;
4、 alter database open;

### 三级标题:ORA-12154 错误概述 ORA-12154 是 Oracle 数据库连接过程中常见的错误之一,表示 PL/SQL 工具无法解析指定的连接标识符。该问题通常与 TNS(Transparent Network Substrate)配置或网络环境有关。 ### 三级标题:检查网络通信 确保本地客户端与远程数据库服务器之间的网络连接正常。通过命令行工具 `ping` 验证是否能够访问目标数据库的 IP 地址或域名。例如: ```bash ping <database_ip_or_hostname> ``` 如果 `ping` 命令失败,则需要检查本地网络设置或联系网络管理员以解决通信问题[^1]。 ### 三级标题:验证 tnsnames.ora 文件配置 确认 `tnsnames.ora` 文件中定义的服务名正确无误,且格式符合要求。服务名前不应包含空格或空行。示例配置如下: ```plaintext ORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = ORCL) ) ) ``` 此外,还需确保文件路径正确,并且 `TNS_ADMIN` 环境变量指向 `tnsnames.ora` 所在目录[^3]。 ### 三级标题:检查监听器配置 运行 `lsnrctl status` 查看监听器状态,确认其是否已启动并监听正确的端口和服务名。若启动,可通过以下命令启动监听器: ```bash lsnrctl start ``` 如果监听器配置缺少 `SID_LIST` 描述项,需手动编辑 `listener.ora` 文件添加相关内容: ```plaintext SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = ORCL) (SID_NAME = ORCL) ) ) ``` 修改后重启监听器以应用更改: ```bash lsnrctl stop lsnrctl start ``` ### 三级标题:测试连接 使用 `tnsping` 测试 TNS 解析是否成功: ```bash tnsping ORCL ``` 若解析失败,应重新检查 `tnsnames.ora` 和 `listener.ora` 配置。同时,尝试通过 SQL*Plus 直接连接数据库以排除 PL/SQL 工具本身的问题: ```bash sqlplus sys/qwe123@orcl as sysdba ``` ### 三级标题:PL/SQL 工具配置 打开 PL/SQL Developer 时选择“Cancel”进入主界面,随后进入工具 -> 首选项 -> 连接部分,确保 Oracle 主目录和 OCI 库路径正确指向 Oracle 客户端安装目录。保存设置后重启 PL/SQL Developer。 ### 三级标题:相关问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值