最近使用jdbc连接oracle时报错:
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor The Connection descriptor used by the client was:
10.12.162.84:1521:xxxx
登陆oracle数据发现在network/admin/文件夹下的tnsnames.ora中配置的是:SERVICE_NAME =xxxx。经过查询发现,是jdbc中的连接串使用的不正确。
Java JDBC Thin Driver 连接 Oracle有三种方法,如下:
格式一: Oracle JDBC Thin using a ServiceName:
jdbc:oracle:thin:@//<host>:<port>/<service_name> 或
jdbc:oracle:thin:@<host>:<port>/<service_name>
Example: jdbc:oracle:thin:@//192.168.2.1:1521/XE 或 jdbc:oracle:thin:@192.168.2.1:1521/XE
注意这里的格式EX前面有/, 这是与使用SID的主要区别。
这种格式是Oracle 推荐的格式,因为对于集群来说,每个节点的SID 是不一样的,但是SERVICE_NAME 确可以包含所有节点。
格式二: Oracle JDBC Thin using an SID:
jdbc:oracle:thin:@<host>:<port>:<SID>
Example: jdbc:oracle:thin:@192.168.2.1:1521:X01A
Note:
Support for SID is being phased out. Oracle recommends that users switch over to usingservice names.
格式三:Oracle JDBC Thin using a TNSName:
jdbc:oracle:thin:@<TNSName>
Example: jdbc:oracle:thin:@GL
Note:
Support for TNSNames was added in the driver release 10.2.0.1
linux下查询sid的方法:
在配置oracle环境变量的情况可以使用 echo $ORACLE_SID,如果没有可以使用ps -ef |grep oracle 来查询:
oracle 2548 1 0 Aug17 ? 00:00:00 ora_pmon_xxxx
后面的xxxx就是对应的sid。
在windows环境下,oracle是以后台服务的方式被管理的,所以看"控制面板->管理工具->服务 里面的名称:"OracleServiceORCL",则ORCL就是sid;
service_name 和sid的区别:
Service_name:该参数是由oracle8i引进的。在8i以前,使用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中,一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐。为了方便并行环境中的设置,引进了Service_name参数,该参数对应一个数据库,而不是一个实例,而且该参数有许多其它的好处。该参数的缺省值为Db_name. Db_domain,即等于Global_name。一个数据库可以对应多个Service_name,以便实现更灵活的配置。该参数与SID没有直接关系,即不必Service name 必须与SID一样
sid是数据库实例的名字,每个实例各不相同。
相关推荐
- **SID与Service Name**: Oracle 11g之前版本通常使用SID,而在11g之后,推荐使用Service Name。 #### 三、SQL Server数据库连接 SQL Server也提供了多种驱动供开发者选择,本文将介绍Microsoft JDBC Driver for ...
连接字符串为`jdbc:oracle:thin:@<host>:<port>:<service_name>`,其中`<service_name>`对应于Oracle服务名或SID。 ### Sybase Sybase数据库曾是企业级应用的首选之一。JDBC驱动`jconn2.jar`用于连接Sybase数据库...
JDBC连接数据库时候,需要使用数据库的sid_name,而不是数据库的service_name,而使用plsql连接数据库的时候,只需要数据库的service_name
- **URL**: 格式为`jdbc:oracle:thin:@hostname:port/service_name`,其中hostname为数据库服务器地址,port为监听端口,service_name为服务名或实例名。 #### 2. DB2 数据库 DB2是IBM的一种高性能关系型数据库...
在上述内容中,列举了使用JDBC连接不同数据库的方式,包括Oracle、DB2、SQL Server、Sybase、Informix、MySQL和PostgreSQL。 1. **Oracle数据库**: - JDBC驱动类:`oracle.jdbc.driver.OracleDriver` - URL模板...
Oracle推荐使用Service Name进行连接,因为它允许连接到Oracle集群中的任何可用节点,而无需关心具体的SID(System Identifier)。JDBC连接字符串的格式为: ```java jdbc:oracle:thin:@//<host>:<port>/<service_...
- 连接字符串格式为`jdbc:oracle:thin:@{hostname}:{port}:{service_id}`,其中`service_id`通常是SID,例如`jdbc:oracle:thin:@localhost:1521:orcl`。 3. **SQL Server 2005数据库连接**: - 引入Microsoft SQL...
- JDBC URL 可以有两种格式,一种是使用服务名:jdbc:oracle:thin:@//<host>:<port>/ServiceName,另一种是使用SID:jdbc:oracle:thin:@<host>:<port>:<SID>。 3. IBM DB2 JDBC 驱动 - DB2 Universal Driver Type 4...
本教程将详细讲解如何使用JDBC测试Oracle数据库的连接,确保你的应用程序能够顺利地与数据库进行通信。 首先,你需要确保已经安装了Oracle数据库,并且知道以下关键信息: 1. 数据库服务器的主机名或IP地址(例如,...
每个数据库都有其特定的JDBC驱动和连接URL格式,确保正确导入驱动类并配置正确的连接参数是成功建立数据库连接的关键。在实际应用中,通常会使用连接池来管理和优化数据库连接,提高性能和资源利用率。
### 常用数据库JDBC URL格式详解 #### 一、引言 Java Database Connectivity (JDBC) 是一套用于执行 SQL 语句的 Java API,它可以为多种关系型数据库提供统一访问,它由一组用 Java 编程语言编写的类和接口组成。...
- Oracle数据库URL格式为jdbc:oracle:thin:@host:port:sid或jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=hostname)(PORT=port))(CONNECT_DATA=(SERVICE_NAME=servicename))) ...
- **连接池**:为了提高性能和资源利用率,通常会使用连接池管理数据库连接,如C3P0、HikariCP等。 总的来说,Oracle 19c的JDBC驱动提供了一个高效、可靠的途径来用Java编程语言与Oracle数据库进行交互。正确理解和...
这里的URL格式是`jdbc:oracle:thin:@<hostname>:<port>:<service_id>`,其中`service_id`是数据库的服务标识符(SID)。 2. **DB2数据库** 对于DB2,我们需要加载`com.ibm.db2.jdbc.app.DB2Driver`驱动,并使用...
6. **数据库连接池**:在企业环境中,通常会使用连接池(如Oracle's Universal Connection Pool)来管理数据库连接,提高性能和资源利用率。 总的来说,Oracle数据库连接涉及网络配置、认证机制以及数据库服务的...
在Java程序中,我们通过JDBC来建立与数据库的连接,执行SQL语句以及处理结果。以下是一些常见数据库的JDBC配置示例: 1. **MySQL数据库** - 驱动加载:`Class.forName("org.gjt.mm.mysql.Driver").newInstance();`...
1. 数据库URL格式:`jdbc:oracle:thin:@//hostname:port/service_name` - `hostname`:Oracle数据库服务器的IP地址或主机名。 - `port`:Oracle监听的TCP/IP端口号,默认为1521。 - `service_name`:Oracle服务名...
2. **格式二:Oracle JDBC Thin using a ServiceName** 这种格式使用Service Name来定位数据库服务,Service Name是Oracle数据库服务的逻辑名称,它可以映射到一个或多个SID,适用于Oracle RAC(Real Application ...
- **设置URL:** URL格式通常为`jdbc:oracle:thin:@hostname:port/service_name`或`jdbc:oracle:thin:@(description=(address=(protocol=tcp)(host=hostname)(port=port))(connect_data=(service_name=service_name))...
URL通常遵循以下格式:"jdbc:oracle:thin:@(description=(address=(host=hostname)(port=port))(connect_data=(service_name=servicename)))" 5. **JDBC优化**: - 使用`PreparedStatement`代替`Statement`,提高...