PL/SQL可以連oracle,但是jdbc連不上 【轉】


 

場景描述

此處是jdbc連接:

try {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    String url = "jdbc:oracle:thin:@xxx.xx.xxx.xxx:1521:xxx";
    conn = DriverManager.getConnection(url, username, password);
} catch (ClassNotFoundException e) {
    e.printStackTrace();
} catch (SQLException e) {
    e.printStackTrace();
}

 

錯誤信息:

java.sql.SQLException: Io 異常: Connection refused(DESCRIPTION=(TMP=)(VSNNUM=169869568)(ERR=12505)(ERROR_STACK=(ERROR=(CODE=12505)(EMFI=4))))
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:333)
    at oracle.jdbc.driver.OracleConnection.<init>(OracleConnection.java:404)
    at oracle.jdbc.driver.OracleDriver.getConnectionInstance(OracleDriver.java:468)
    at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:314)
    at java.sql.DriverManager.getConnection(DriverManager.java:582)

 

首先,說賬號密碼寫錯了的,我強調一下,賬號密碼真的沒錯,如果賬號密碼錯了,會報下面的錯誤

java.sql.SQLException: ORA-01017: 用戶名/口令無效; 登錄被拒絕

    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)
    at oracle.jdbc.ttc7.TTIoer.processError(TTIoer.java:289)
    at oracle.jdbc.ttc7.O3log.receive2nd(O3log.java:496)
    at oracle.jdbc.ttc7.TTC7Protocol.logon(TTC7Protocol.java:278)
    at oracle.jdbc.driver.OracleConnection.<init>(OracleConnection.java:346)

 

PL/SQL連接沒問題

用的客戶端,下面是配置文件

文件tnsnames.ora

ORCL =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = 1521))

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME =xxx)

    )

  )

 

問題就這么莫名其妙的產生了,PL/SQL能連上,程序連不上

 

在解決問題之前,先看看oracle數據庫的一些知識

  1. 數據庫名
    數據庫名就是一個數據庫的標識,每一個數據庫都有一個數據庫名。在數據庫安裝或創建完成之后,參數DB_NAME被寫入參數文件之中。
  2. 數據庫實例名(instance name)
    數據庫實例名則用於和操作系統之間的聯系,用於對外部連接時使用。在操作系統中要取得與數據庫之間的交互,必須使用數據庫實例名。
  3. ORACLE_SID
    用於和操作系統交互,在操作系統中要想得到實例名,就必須使用ORACLE_SID。ORACLE_SID必須與instance_name的值一致。
  4. 數據庫服務名(SERVICE_NAMES)
    與全局數據庫名相同如果沒有域名,則服務名就是數據庫名。
  5. 數據庫域名
    用於區別同名數據庫。數據庫名與域名一起構成了全局數據庫名。

SID即使SERVICE_NAMES,一個數據庫對應一個實例

 

PL/SQL通過tnsnames.ora連接

可以配置服務名、sid等,都行

jdbc連接

SID方式

 jdbc:oracle:thin:@<host>:<port>:<SID>

 

SERVICE_NAMES方式

jdbc:oracle:thin:@//<host>:<port>/ServiceName

 

我在tnsnames.ora中默認配置的服務名,但是jdbc用的sid連接方式,說明很有可能是客戶給我的,不是實例名(SID),而是一個庫名,庫名又和服務名相同

那么則可以用service_name方式連接  或者用:

jdbc:oracle:thin:@(DESCRIPTION = (ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = 1521)))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME =xxx)))

 

引用自: http://blog.csdn.net/king_818/article/details/53034374

暫時有些看不懂,下次回來再看,mark


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM