从 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