从 Java 连接到 Oracle DB 时出错

Posted

技术标签:

【中文标题】从 Java 连接到 Oracle DB 时出错【英文标题】:Error connecting to Oracle DB from Java 【发布时间】:2011-11-12 11:22:17 【问题描述】:

有人可以帮我解释为什么我在尝试从 java 连接到 Oracle db 时收到以下错误....

连接调用是:

Connection con = DriverManager.getConnection(
     "jdbc:oracle:thin:@winson.net:1522/hcrod", 
     "manager", "passing");

我收到以下错误:

java.sql.SQLException: Listener refused the connection with the following error:
ORA-12514, TNS:listener does not currently know of service requested in connect descriptor
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:113)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:263)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:389)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:454)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:165)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:35)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:802)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at test_sample.main(test_sample.java:15)

【问题讨论】:

【参考方案1】:

在类似的情况下,我使用了一个稍微不同的连接字符串: jdbc:oracle:thin:@winson.net:1522:hcrod

真的没有 // 和 : 而不是 /

【讨论】:

【参考方案2】:

在启动数据库后启动 TNS 侦听器时,我曾多次看到此错误。当数据库启动时,如果侦听器正在运行,它会向侦听器注册自己,但如果侦听器没有运行,它就不能这样做。

可以手动说服数据库向侦听器注册自身。为此,请以SYS 身份连接到数据库并运行SQL 语句ALTER SYSTEM REGISTER;

【讨论】:

我已经给出了你唯一需要的命令。以 sys 身份登录 - 我知道您可以像 commented on this answer 那样执行此操作 - 并运行我提到的一个命令。【参考方案3】:

听起来服务器上的端口没有在监听,端口 1522。

你能telnet端口成功吗?

【讨论】:

连接主机 'winson.net:1522/hcrod' 是正确的,因为我可以通过 SQL 开发者成功连接到它。【参考方案4】:

Oracle 的 JDBC 瘦 URI 语法如下:

jdbc:oracle:thin:[USER/PASSWORD]@//[HOST][:PORT]/SERVICE

所以:

jdbc:oracle:thin:@//winson.net:1522/hcrod"

注意@符号后添加的两个斜线。

【讨论】:

【参考方案5】:

我认为 oracle 的端口号是 1521

【讨论】:

以上是关于从 Java 连接到 Oracle DB 时出错的主要内容,如果未能解决你的问题,请参考以下文章

Tableau Server 连接到 ODBC 驱动程序时出错

使用带有 node-oracledb 的 SID 连接到 Oracle DB 失败

Sqoop - 尝试连接到 Oracle DB 服务器时出现 java.lang.NullPointerException

使用 PGAdmin 连接到 Heroku DB 时出错

在nodejs中连接到heroku postgres db时出错

无法从 C# 通过 Wallet 连接到 Oracle DB