PL/SQL可以連oracle,但是jdbc連不上
阿新 • • 發佈:2018-12-31
先看一下錯誤資訊
此處是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資料庫的一些知識
- 資料庫名
資料庫名就是一個數據庫的標識,每一個數據庫都有一個數據庫名。在資料庫安裝或建立完成之後,引數DB_NAME被寫入引數檔案之中。 - 資料庫例項名(instance name)
資料庫例項名則用於和作業系統之間的聯絡,用於對外部連線時使用。在作業系統中要取得與資料庫之間的互動,必須使用資料庫例項名。 - ORACLE_SID
用於和作業系統互動,在作業系統中要想得到例項名,就必須使用ORACLE_SID。ORACLE_SID必須與instance_name的值一致。 - 資料庫服務名(SERVICE_NAMES)
與全域性資料庫名相同如果沒有域名,則服務名就是資料庫名。 - 資料庫域名
用於區別同名數據庫。資料庫名與域名一起構成了全域性資料庫名。
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)))
方式