我正在尝试使用 Oracle JDBC 瘦驱动程序(11.2.0.2.0 的 ojdbc6.jar)和以下 JDBC URL 语法连接到 Oracle (11.2.0.2.0) 数据库:
jdbc:oracle:thin:@abcd
Run Code Online (Sandbox Code Playgroud)
其中 'abcd' 在我的 tnsnames.ora 文件中定义,如下所示:
abcd, abcd.world, abcd.dk.xyz.com =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
(CONNECT_DATA =
(SERVICE_NAME = abcd)
)
)
Run Code Online (Sandbox Code Playgroud)
我已-Doracle.net.tns_admin=/etc/tnsnames.ora根据Oracle® Database JDBC Developer's Guide and Reference提供了 VM 选项。
运行应用程序时出现以下错误:
Listener refused the connection with the following error:
ORA-12504, TNS:listener was not given the SID in CONNECT_DATA
Run Code Online (Sandbox Code Playgroud)
但是当我从 tnsnames.ora 中删除别名 abcd.world 和 abcd.dk.xyz.com 时,我的应用程序能够连接到数据库。
当 tnsnames.ora 文件中有多个别名时,ojdbc 驱动程序是否有问题?
我的 JDK 版本是 1.6.0_31。
谢谢,VJ
小智 5
看起来,Oracle JDBC 驱动程序不能使用多个服务名称。使用这些条目
abcd =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
(CONNECT_DATA =
(SERVICE_NAME = abcd)
)
)
abcd.world, abcd.dk.xyz.com =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = abcd.dk.xyz.com)(PORT = 1521))
(CONNECT_DATA =
(SERVICE_NAME = abcd)
)
)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
22643 次 |
| 最近记录: |