19

tnsnames.ora文件包含Databases及其描述 ( host+ port)。

  • 是否可以根据上述文件建立连接?(比如说只提供数据库名称):

  • 为了找到这个文件,我必须知道默认的 oracle home,我需要在 windows 注册表中检查,HKEY_LOCAL_MACHINE\Software\Oracle然后拥有所有KEY_XXX文件,然后检查哪个文件首先出现在%PATH%. 有没有办法在客户端计算机上自动找到这个文件?

4

5 回答 5

26

我什至不知道可以将 tnsnames 与瘦驱动程序一起使用,但显然它是在版本 10 中添加的:

http://docs.oracle.com/cd/B19306_01/java.102/b14355/urls.htm#BEIDIJCE

尤其:

笔记:

将 TNSNames 与 JDBC Thin 驱动程序一起使用时,必须将 oracle.net.tns_admin 属性设置为包含 tnsnames.ora 文件的目录。

java -Doracle.net.tns_admin=%ORACLE_HOME%\network\admin

如前所述,我还没有检查这是否真的有效。

我不认为“查找实际的网络配置目录”逻辑可通过某些 Oracle 函数获得。您必须按照问题中所述手动执行此操作,或者可能依赖存在的 TNS_ADMIN 环境变量。在这种情况下,java 调用将是

java -Doracle.net.tns_admin=%TNS_ADMIN%
于 2013-01-07T11:38:58.457 回答
16

好吧,在某些 GUI 中,TNS 驱动程序配置根本没有实现或无法正常工作(例如 NetBeans :-))

https://netbeans.org/bugzilla/show_bug.cgi?id=231526

这里有一个简单的解决方法。您可以直接从 tnsnames.ora 文件中获取条目并将其附加到 jdbc 驱动程序字符串,如下所示:

使用 odbc7.jar(适用于 JDK 7 的 Oracle 12c JDBC 驱动程序)连接到 Oracle 11gR2 RAC 集群的示例:

jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL= TCP)(HOST=hostA)(PORT= 1522))(ADDRESS=(PROTOCOL=TCP)(HOST=hostB)(PORT=1521) ))(SOURCE_ROUTE=yes)(CONNECT_DATA=(SERVICE_NAME=DatabaseService)))

请注意将双 :: 字符放在最后作为主机:端口:服务,如果您将 :: 放在最后,如下所示:

jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL= TCP)(HOST=hostA)(PORT= 1522))(ADDRESS=(PROTOCOL=TCP)(HOST=hostB)(PORT=1521) ))(SOURCE_ROUTE=yes)(CONNECT_DATA=(SERVICE_NAME=DatabaseService)))::

您最终会遇到“NL Exception was generated”异常。

另一种方法是配置以下属性: System.setProperty("oracle.net.tns_admin","C:/app/product/11.2.0/client_1/NETWORK/ADMIN");

当然,您可以在操作系统中设置环境变量,例如 ORACLE_TNS_ADMIN,然后引用它,而不是硬编码值:

System.setProperty("oracle.net.tns_admin",System.getenv("ORACLE_TNS_ADMIN"));

或者通过 linux 上的 -D 开关将其传递给 java 进程:

-Doracle.net.tns_admin=$ORACLE_TNS_ADMIN

和窗口:作为

-Doracle.net.tns_admin=%ORACLE_TNS_ADMIN%

一旦我们的应用程序知道 TNS 配置文件,我们可以通过 TNSNAMES.ora 文件中的引用服务名称进行连接,如下面的完整示例所示:

 // tell the driver where to look for the TNSNAMES.ORA file
System.setProperty(
          "oracle.net.tns_admin",
          "C:/app/product/11.2.0/client_1/NETWORK/ADMIN");

// ORCL is net service name from the TNSNAMES.ORA file
String dbURL = "jdbc:oracle:thin:@ORCL";

// load the driver
Class.forName("oracle.jdbc.OracleDriver");

Connection conn = null;
Statement stmt = null;

try {
  conn = DriverManager.getConnection(dbURL,
                                     "your_username",
                                     "your_password");

  stmt = conn.createStatement();

  ResultSet rs = stmt.executeQuery("SELECT dummy FROM dual");
于 2014-07-16T12:32:33.390 回答
5

从 18.3 开始,提供 tnsnames.ora 文件位置的 TNS_ADMIN 可以作为连接 URL 的一部分传递。请注意语法。

jdbc:oracle:thin:@jdbctest_medium?TNS_ADMIN=/test/cloud/network
于 2019-10-17T19:32:13.260 回答
4

首先确保 SQL Developer 软件已正确安装在您的计算机中。如果您使用的是瘦驱动程序,请确保您的 ojdbcX.jar 文件位于您的构建路径中。使用 TNS 别名连接到 Oracle 数据源的步骤是:

  • 为 设置系统属性oracle.net.tns_admin。这应该指向包含您的tnsnames.ORA文件的目录

    System.setProperty("oracle.net.tns_admin", DIRECTORY_PATH_TO_TNSNAME.ORA_FILE);

  • 注册 Oracle 驱动程序

    DriverManager.registerDriver(new OracleDriver());

  • 创建连接对象

    Connection conn = DriverManager.getConnection("jdbc:oracle:thin:username/password@TNS_ALIAS_NAME");

这应该建立数据库连接。

于 2016-07-28T10:56:35.920 回答
2

您也可以尝试以下方法

试试这个,经过几个小时的故障排除后,我发现了一个我修改过的示例,它就像一个宝石一样工作。

jdbc:oracle:thin:@(description=(address_list=(address=(protocol=tcp)(port=1521)(host=19.16.200.12)) (address=(protocol=tcp)(port=1521)(host=19.16.200.10)))(load_balance = yes)(connect_data=(SERVICE_NAME=stackdb)))

下面给出了一个无负载平衡示例:

jdbc:oracle:thin:@(description=(address_list=(address=(protocol=tcp)
(port=1521)(host=prodHost)))(connect_data=(INSTANCE_NAME=ORCL)))

这是帮助https://docs.oracle.com/cd/E11882_01/java.112/e16548/jdbcthin.htm#JJDBC28202的 URL

于 2019-10-09T20:17:46.597 回答