1. 程式人生 > >PL/SQL可以連oracle,但是jdbc連不上

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)))

方式