ORA-12505: TNS: 监听程序当前无法识别连接描述符中所给出的SID等错误解决方法

程序连接orarle报ORA-12505错误

一、异常{

ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

The Connection descriptor used by the client was:

10.190.121.95:1521:sxzhdb

}

二、查询{

ORA-12505:TNS: 监听程序当前无法识别连接描述符中所给出的 SID

 

SID:是一个数据库的唯一标识符!是建立一个数据库时系统自动赋予的一个初始ID,SID主要用于在一些DBA操作以及与操作系统交互,从操作系统的角度访问实例名,必须通过ORACLE_SID,且它在注册表中也是存在的.

 

ORACLE_SID就是Oracle System Identifier.在Oracle系统中,ORACLE_SID以环境变量的形式出现,当Oracle实例启动时,操作系统上fork的进程必须通过这个SID将实例与其他实例区分开来,这就是SID的作用。

}

三、修改{

将原来的:jdbc:oracle:thin:@10.190.121.95:1521:sxzhdb

改为:jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.190.121.95)(PORT=1521))(LOAD_BALANCE=yes))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=sxzhdb)))

后,程序连接数据库OK。

------

最后将:url简化为:jdbc:oracle:thin:@(description=(address=(protocol=tcp)(port=1521)(host=10.190.121.95))(connect_data=(service_name=sxzhdb)))

----

其中address的三个属性protocol,port,host顺序可以变化,大小写均可以。

结构为:

description

        address

               protocol

               host

               port

        connect_data

               service_name

}

转载于:https://www.cnblogs.com/qianyuliang/p/8855944.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你遇到cx_Oracle.DatabaseError: ORA-12505: TNS: 监听程序当前无法识别连接描述符中所给出SID时,这通常意味着在尝试通过Oracle Net Services(如TCP/IP或共享内存)连接数据库服务器时,存在一些问题。以下是可能的原因及解决步骤: 1. **SID未配置**:确认你的连接字符串中指定的Service Name (SN) 或者 SID是否与实际数据库的名称一致。如果新安装了数据库或者更改了服务名,需要更新连接信息。 2. **监听器(Listener)问题**:检查Oracle Listener是否正在运行并且配置正确。你可以通过命令`lsnrctl status`查看监听器状态。如果没有启动,运行`lsnrctl start`。 3. **防火墙或网络问题**:确保数据库服务器的端口(默认为1521)在防火墙上是开放的,并且你的应用程序可以从网络访问。 4. **TNS文件(Naming Service)错误**:核实TNS名字解析路径是否指向正确的配置文件,通常是`%ORACLE_HOME%\network\admin\tnsnames.ora`。 5. **环境变量设置**:确认你的系统环境变量`TNS_ADMIN`设置到了tnsnames.ora文件所在的目录。 6. **证书或身份验证**:如果是SSL连接,确保客户端和服务器之间的信任链已建立,且使用的用户名和密码或证书是有效的。 如果你遇到这个问题,建议你在排查时逐项检查以上可能原因,并尝试相应的解决方案。同时,记录下错误的日志可能会提供更详细的诊断信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值