ORA-12505: TNS: 監聽程式當前無法識別連線描述符中所給出的SID等錯誤解決方法

淺雨涼發表於2018-04-16

程式連線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

}

相關文章