如何使用带有 TNSNames 别名语法的 JDBC 瘦驱动程序连接到 Oracle 数据库

V.J*_*.J. 3 java jdbc

我正在尝试使用 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)