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主要⽤于在⼀些D
jdbc连接oracleBA操作以及与操作系统交互,从操作系统的⾓度访问实例名,必须通过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
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。