4

oracle express 11gエディションをダウンロードしてインストールしましたが、Javaアプリケーションから接続したいと思います。これが私の接続コードです:-

Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:example", "example","password123");

しかし、接続しようとすると、次の例外が表示されます。

java.sql.SQLException: Listener refused the connection with the following error:  
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:419)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:536)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:228)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:521)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at javaapplication3.JavaApplication3.main(JavaApplication3.java:40)

しかし、「xe」データベースに接続しようとすると、接続されます。

Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();   
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe", "example","password123");

なぜこれが起こっているのか分かりませんか?参考資料やヒントを教えてください。

4

4 に答える 4

8

database schemaとデータベースの種類を誤解していると思います。でOracle、OracleデータベースをXE意味します。を意味します。Express EditionORCLOracle Corp

mysqlでは

DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "example","password123");

`test` is a database schema.

OracleXEの場合

DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe", "example","password123");
DriverManager.getConnection("jdbc:oracle:thin:scott/tiger@myhost:1521:orcl","example", "password123");

`example`: database schema name and DB user name are the same.
于 2012-11-01T11:31:03.917 に答える
5

Oracleの接続URLは次の形式です。

jdbc:oracle:thin:@HOST:PORT:SID

SIDはサイト識別子です。Oracleの完全インストールでは、複数のSIDを持つことができますが、Oracle Expressの場合、これは常にになりますXE

「データベース」と呼んでいるものは、Oracleの「ユーザー」(上記のコードの「例」)に相当します。テーブルなどはそのユーザーの下に作成されます。

于 2012-11-01T11:30:25.823 に答える
1

URLパターンでは、XEとorclはOracleのサービスIDです。OracleExpressedエディションの場合は「xe」が使用され、OracleEnterprisedエディションの場合は「orcl」が使用されます。

于 2013-12-29T10:38:59.897 に答える
0

: lsnrctl servicesを実行して、リスナーに認識されているインスタンスを確認します。

tnsnames.oraを確認してください

SIDパラメータのタイプミスと無効なパラメータ値を確認してください

于 2012-11-01T11:28:52.687 に答える