在java应用程序中与oracle连接

时间:2012-11-01 11:07:21

标签: java oracle connection

我已经下载了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 个答案:

答案 0 :(得分:8)

我认为,您在database schema和数据库类型之间存在误解。在Oracle中,XE表示oracle数据库的Express EditionORCL表示Oracle Corp

在mysql中

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

`test` is a database schema.

在Oracle XE中

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.

答案 1 :(得分:4)

Oracle的连接URL格式为:

JDBC:预言:瘦:@HOST:PORT:SID

SID是站点标识符。在完整的oracle安装中,您可以拥有多个SID,但对于Oracle Express,这将始终为XE

您所称的“数据库”等同于Oracle中的“用户”(上面代码中的“示例”)。表等...是在该用户下创建的。

答案 2 :(得分:0)

执行以下操作检查侦听器已知的实例: lsnrctl services

检查你的tnsnames.ora

检查您的SID参数是否存在拼写错误和无效参数值

答案 3 :(得分:0)

在URL模式中,XE和orcl是Oracle的服务ID。 对于Oracle表达版本“xe”用于Oracle企业版 使用“orcl”..