程序啓動報錯:ORA-12505;PL/SQL卻能夠登陸的解決方法

1、異常{html

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
}
 
2、查詢{
ORA-12505:TNS: 監聽程序當前沒法識別鏈接描述符中所給出的 SID
---
SID:是一個 數據庫的惟一標識符!是創建一個數據庫時系統自動賦予的一個初始ID,SID主要用於在一些DBA操做以及與操做系統交互,從操做系統的角度訪問實例名,必須經過ORACLE_SID,且它在註冊表中也是存在的.
---
ORACLE_SID就是 Oracle System Identifier.在Oracle 系統中,ORACLE_SID以環境變量的形式出現,當Oracle實例啓動時,操做系統上fork的進程必須經過這個SID將實例與其餘實例區分開來,這就是SID的做用。
}
 
3、修改{
將原來的: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
}
 
轉載地址:http://www.2cto.com/database/201203/124950.html
相關文章
相關標籤/搜索