最近使用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>
Example: jdbc:oracle:thin:@//192.168.2.1:1521/XE
注意这里的格式,@后面有//, 这是与使用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
// orcl为数据库SID String user = "test"; String password = "test"; Connection conn = DriverManager.getConnection(url, user, password); ``` - **Class.forName**: 加载指定的JDBC驱动。 - **DriverManager...
在实际应用中,应根据所使用的数据库类型和版本查阅相应的官方文档,确保使用正确的驱动类和连接参数。此外,为了提高代码的可读性和维护性,建议使用连接池来管理数据库连接,如C3P0、HikariCP或Apache DBCP。
Oracle推荐使用Service Name进行连接,因为它允许连接到Oracle集群中的任何可用节点,而无需关心具体的SID(System Identifier)。JDBC连接字符串的格式为: ```java jdbc:oracle:thin:@//<host>:<port>/<service_...
本文将详细介绍如何使用JDBC连接字符串和方法来连接不同的数据库,包括MySQL、Oracle、SQLServer2005、Access、SQL Server7.0/2000、DB2以及Sybase。 1. **MySQL数据库连接**: - 首先,你需要在项目中引入`mysql-...
- 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格式,确保正确导入驱动类并配置正确的连接参数是成功建立数据库连接的关键。在实际应用中,通常会使用连接池来管理和优化数据库连接,提高性能和资源利用率。
- **连接池**:为了提高性能和资源利用率,通常会使用连接池管理数据库连接,如C3P0、HikariCP等。 总的来说,Oracle 19c的JDBC驱动提供了一个高效、可靠的途径来用Java编程语言与Oracle数据库进行交互。正确理解和...
- 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))) ...
6. **数据库连接池**:在企业环境中,通常会使用连接池(如Oracle's Universal Connection Pool)来管理数据库连接,提高性能和资源利用率。 总的来说,Oracle数据库连接涉及网络配置、认证机制以及数据库服务的...
在Java程序中,我们通过JDBC来建立与数据库的连接,执行SQL语句以及处理结果。以下是一些常见数据库的JDBC配置示例: 1. **MySQL数据库** - 驱动加载:`Class.forName("org.gjt.mm.mysql.Driver").newInstance();`...
这里的URL格式是`jdbc:oracle:thin:@<hostname>:<port>:<service_id>`,其中`service_id`是数据库的服务标识符(SID)。 2. **DB2数据库** 对于DB2,我们需要加载`com.ibm.db2.jdbc.app.DB2Driver`驱动,并使用...
- `jdbc:oracle:thin:@//<host>:<port>/ServiceName` - 或 `jdbc:oracle:thin:@<host>:<port>:<SID>` - `<SID>`:服务标识符,通常用于早期版本。 - `<ServiceName>`:服务名称,通常用于较新版本。 #### 四、...
- `service_name`:Oracle服务名,可以在tnsnames.ora配置文件中找到或直接使用SID。 2. 示例代码: ```jsp *" %> String url = "jdbc:oracle:thin:@//localhost:1521/orcl"; String username = "your_...
- **设置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`,提高...
在Oracle 9i及之前版本中,SID主要用于连接数据库,而在之后的版本中,随着Service Name的引入,推荐使用服务名来连接,因为服务名可以映射到多个SID,提供了更好的可扩展性和高可用性。然而,SID仍然是兼容的,并且...