数据库名实例名服务名

数据库名:db_name            数据库实例名:instance_name

操作系统环境变量:oracle_sid    数据库服务名:service_names
数据库域名:db_domain         全局数据库名:global_db_name
在oracle7、oracle8数据库中只有数据库名以及实例名,在oracle8i、oracle9i中出现了数据库域名、服务名以及全局数据库名。
数据库名( db_name ):用于区分一个数据的内部标识,是oracle的内部标记,是以二进制方式存储于数据库控制文件的参数。
数据库名的作用:数据库名是数据库的内部管理标记,在安装数据库、创建新的的数据库、创建数据库控制文件、修改数据库结构、使用数据库备份与恢复工具进行数据库备份时都需要使用数据名。
数据库安装完成后,数据库名称存储在 参数文件(pfile,spfile)中,同时以二进制方式存储在 控制文件中,两者必须匹配。如果两者不匹配,数据库在启动时提示ORA-01103号错误。
对数据名称的查询:
1、查询参数文件 db_name的数值
2、select name from v$database
3、SQL>show parameter db_name
修改数据库名(修改复杂,建议不要修改)
1、修改参数文件的数据库名称。
2.重建数据库的控制文件。
 
数据库实例名( instance_name ):用于和操作系统之间的联系。
操作系统与数据库之间的交互则必须使用数据库实例名。数据库安装完成后,数据库实例名称存储在 参数文件中,同时存储在 注册表中。
数据库名与实例名一般是一一对应的关系,即:有一个数据库名就有一个实例名,而在oracle9i的并行服务器结构中是一对多的关系,即:一个数据库对应多个实例。
对数据名称的查询:
1、查询参数文件 instance_name的数值
2、select instance_name from v$instance
3、SQL>show parameter instance_name
 
操作系统环境变量 (oracle_sid):用于与数据库实例名相对应。instance_name是oracle数据库参数-oracle_sid是操做系统环境变量,即在操作系统要得到实例名必须通过操做系统环境变量oracle_sid, oracle_sid instance_name 必须相同。
是数据库和操作系统的接口,由操作系统使用,是操作系统区分多个数据库的依据。oracle_sid存储在 注册表中。如果数据库的oracle_sid与实际的instance_name不同,在操作系统下运行的oracle所有命令将产生错误。
对数据实例名的定义:
SQL>set oracle_sid=数据库实例名
 
数据库域名( db_domain ):在数据库名称后增加域名构成,使得数据库的取名在整个网络环境中惟一,主要用于oralce分布式环境中数据的远程复制。数据库域名存储在 参数文件中。
以下情况要考虑使用数据库域名:1、在oracle分布式环境下,两个数据库之间要通过数据链路进行数据的远程传输。2、在同一网络环境下,两个数据库名相同。
对数据库域名的查询:
1、查询参数文件 db_domain的数值
2、select value from v$parameter where name='db_domain'
3、SQL>show parameter db_domain
修改数据库域名:
1、关闭数据库
2、修改数据库参数文件中的db_domain、service_names。
 
数据库服务名 service_names 数据库名+数据库域名,意义与全局数据库名相同。
数据库服务名存储在 参数文件中。
对数据库服务名的查询:
1、查询参数文件 service_names的数值
2、select value from v$parameter where name='service_names'
3、SQL>show parameter service_names
 
全局数据库名 global_db_name 数据库名+数据库域名。

你可能感兴趣的:(数据库,服务名)