`
fjjiaboming
  • 浏览: 33175 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

数据库名,实例名,数据库域名,全局数据库名,服务名

    博客分类:
  • SQL
SQL 
阅读更多
一、数据库名
什么是数据库名?
数据库名就是一个数据库的标识,就像人的身份证号一样。他用参数DB_NAME表示,如果一台机器上装了多个数据库,那么每一个数据库都有一个数据库名。在数据库安装或创建完成之后,参数DB_NAME被写入参数文件之中。

在创建数据库的时候需要指定对应实例名(instance_name)(数据库名和实例名可以相同也可以不同)。

同时数据库名会在windows 服务中显示在OracleServiceORCL最后的四个字符(orcl)。
格式如下:
DB_NAME=myorcl
...
在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。因为,数据库名还被写入控制文件中,控制文件是以二进制型式存储的,用户无法修改控制文件的内容。假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。但是在Oracle启动时,由于参数文件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。

数据库名的作用
数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、备份与恢复数据库时都需要使用到的。
有很多Oracle安装文件目录是与数据库名相关的,如:
winnt: d:/oracle/product/10.1.0/oradata/DB_NAME/...
Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/...
pfile:
winnt: d:/oracle/product/10.1.0/admin/DB_NAME/pfile/ini.ora
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.ora
跟踪文件目录:
winnt: /home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...
另外,在创建数据时,careate database命令中的数据库名也要与参数文件中DB_NAME参数的值一致,否则将产生错误。
同样,修改数据库结构的语句alter database, 当然也要指出要修改的数据库的名称。
如果控制文件损坏或丢失,数据库将不能加载,这时要重新创建控制文件,方法是以nomount方式启动实例,然后以create controlfile命令创建控制文件,当然这个命令中也是指指DB_NAME。
还有在备份或恢复数据库时,都需要用到数据库名。
总之,数据库名很重要,要准确理解它的作用。

查询当前数据名
方法一:select name from v$database;
方法二:show parameter db
方法三:查看参数文件。

修改数据库名
前面建议:应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是一件比较复杂的事情。那么现在就来说明一下,如何在已创建数据之后,修改数据库名。步骤如下:
1.关闭数据库。
2.修改数据库参数文件中的DB_NAME参数的值为新的数据库名。
3.以NOMOUNT方式启动实例,修建控制文件(有关创建控制文件的命令语法,请参考oracle文档)

二、数据库实例名(instance_name)
什么是数据库实例名?
数据库实例名是用于和操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。实例名也被写入参数文件中,该参数为instance_name,在winnt平台中,实例名同时也被写入注册表。
数据库名和实例名可以相同也可以不同。
在一般情况下,数据库名和实例名是一对一的关系,但如果在oracle并行服务器架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。



instance由一个内存区域(SAG)和一组后台进程组成,其作用是对数据库进行管理、提高性能, 名字为SID_NAME,一个instance管理一个数据库(OPS除外)。



数据库名与实例名之间的关系。
数据库名与实例名之间的关系一般是一一对应关系,有一个数据库名就有一个实例名,如果在一个服务器中创建两个数据库,则有两个数据库名,两个数据库实例名,用两个标识确定一个数据库,用户和实例相连接。
但在8i、9i的并行服务器结构中,数据库与实例之间不存在一一对应关系,而是一对多关系,(一个数据库对应多个实例,同一时间内用户只一个实例相联系,当某一实例出现故障,其它实例自动服务,以保证数据库安全运行。)

查询当前数据库实例名
方法一:select instance_name from v$instance;
方法二:show parameter instance
方法三:在参数文件中查询。

实例名(Instance_name)与操作系统环境变量(ORACLE_SID)
虽然两者都表示oracle实例,但两者是有区别的。instance_name是oracle数据库参数。而ORACLE_SID是操作系统的环境变量。ORACLD_SID用于与操作系统交互,也就是说,从操作系统的角度访问实例名,必须通过ORACLE_SID。在winnt不台,ORACLE_SID还需存在于注册表中。
且ORACLE_SID必须与instance_name的值一致,否则,你将会收到一个错误,在unix平台,是“ORACLE not available”,在winnt平台,是“TNS:协议适配器错误”。




(ORACLE_SID)



    OS  <------------->ORACLE 数据库<------(Instance_name(实例名))
上图表示实例名instance_name、操作系统环境变量ORACLE_SID与数据库及操作系统之间的关系,虽然这里列出的两个参数都是数据库实例名,但instance_name参数是ORACLE数据库的参数,此参数可以在参数文件中查询到,而ORACLE_SID参数则是操作系统环境变量。
操作系统环境变量ORACLE_SID用于和操作系统交互。也就是说,在操作系统中要想得到实例名,就必须使用ORACLE_SID。此参数与ORACLE_BASE、ORACLE_HOME等用法相同。在数据库安装之后,ORACLE_SID被用于定义数据库参数文件的名称。如:
$ORACLE_BASE/admin/DB_NAME/pfile/init$ORACLE_SID.ora。
定义方法:
export ORACLE_SID=orcl



如果在同一服务器中创建了多个数据库,则必然同时存在多个数据库实例,这时可以重复上述定义过程,以选择不同实例。

还可以用 [oracle@Datacent]$ . oraenv 来切换不同的ORACLE_SID,以此通过操作系统来启动不同的实例(instance)





数据库实例名与网络连接
数据库实例名除了与操作系统交互外,还用于网络连接的oracle服务器标识。当你配置oracle主机连接串的时候,就需要指定实例名。当然8i以后版本的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。

三、数据库域名
什么是数据库域名?
在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于oracle分布式环境中的复制。举例说明如:
全国交通运政系统的分布式数据库,其中:
福建节点: fj.jtyz
福建厦门节点: xm.fj.jtyz
江西: jx.jtyz
江西上饶:sr.jx.jtyz
这就是数据库域名。
数据库域名在存在于参数文件中,他的参数是db_domain.

查询数据库域名
方法一:select value from v$parameter where name = 'db_domain';
方法二:show parameter domain
方法三:在参数文件中查询。

全局数据库名
全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:oradb.fj.jtyz

四、数据库服务名
什么是数据库服务名?
从oracle9i版本开始,引入了一个新的参数,即数据库服务名。参数名是SERVICE_NAME。
如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。

查询数据库服务名
方法一:select value from v$parameter where name = 'service_name';
方法二:show parameter service_name
方法三:在参数文件中查询。

数据库服务名与网络连接
从oracle8i开始的oracle网络组件,数据库与客户端的连接主机串使用数据库服务名。

而8i之前用的是ORACLE_SID,即数据库实例名。


服务名就是OracleServiceORCL
ORACLE的数据库是一组文件的集合,数据库的名字为DBNAME。

例子
如在ORACLE SERVER上安装一个
数据库其名为    D1
INSTANCE_NAME:    INS1
SERVICE_NAME:      ABC, CCC.

用户连接时:

CONNECT  user/password @ABC

CONNECT  user/password @CCC
都连接到D1数据库上。


++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
有应聘"MySQL/MariaDB,运维/开发", 请发邮件至: linzuxiong1988@gmail.com, 并取得联系.
分享到:
评论

相关推荐

    数据库名 实例名 数据库域名 全局数据库名 服务名

    ### 数据库名、实例名、数据库域名、全局数据库名、服务名详解 #### 一、数据库名 **定义**:数据库名(Database Name)是指在安装数据库系统时为该数据库指定的一个唯一标识符,它类似于人的身份证号,是区分不同...

    学案之数据库名实例名数据库域名全局数据库名服务名.pdf

    - 数据库域名是数据库的网络标识,它包括数据库名和域名,形成全局数据库名(Global Database Name)。 - 全局数据库名用于数据库的网络连接和分布式数据库系统中,确保数据库在整个网络中的唯一性。 - 示例:...

    详解_数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名

    详解_数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名

    oracle实例名,数据库名,服务名等概念区别与联系.doc

    Oracle 数据库中有多个概念经常让初学者感到困惑,例如数据库名、实例名、数据库域名、全局数据库名、服务名等。今天我们将详细解释这些概念的区别和联系。 数据库名 (DB_NAME) 数据库名是数据库的标识,就像人的...

    oracle 数据库名、实例名、数据库域名、全局数据库名、服务名 解析

    ### Oracle 数据库名、实例名、数据库域名、全局数据库名、服务名 解析 #### 一、Oracle数据库名称(DB_NAME) 在Oracle数据库系统中,**数据库名称**(DB_NAME)是一个非常重要的概念,用于唯一标识一个特定的...

    数据库名、实例名、数据库域名、全局数据库名、服务名.pdf

    ### 数据库名、实例名、数据库域名、全局数据库名、服务名详解 #### 一、数据库名 **定义**: 数据库名(Database Name)是指一个数据库的唯一标识符,类似于人的身份证号码。它用于区分同一台机器上的多个数据库...

    数据库名、实例名、数据库域名、全局数据库名、服务名[归类].pdf

    ### 数据库名、实例名、数据库域名、全局数据库名、服务名详解 #### 一、数据库名 **定义**: 数据库名(Database Name)是指一个数据库的唯一标识符,类似于人的身份证号码。它用于区分同一台机器上的多个数据库...

    详解数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名[参考].pdf

    ### 详解数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名 在深入了解Oracle数据库的管理及维护过程中,理解数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名和服务名等核心概念至关重要。...

    ORACLE_SID_实例名_数据库名_讲解

    ORACLE_SID、实例名、数据库名、数据库域名、全局数据库名、服务名 数据库名是指一个数据库的标识,类似于人的身份证号,用于标识一个数据库。它由参数 DB_NAME 表示,在数据库安装或创建完成之后,参数 DB_NAME 被...

    oracle实例名,服务名等概念区别与联系

    实例名是用于与操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。实例名也被写入参数文件中,该参数为 instance_name。在 winnt 平台中,实例名同时也被写入注册表。数据库名和实例名...

    Oracle 9i安装中的全局数据库名及SID

    - **关联性**:全局数据库名和SID共同决定了一个数据库实例在网络中的唯一性。通常情况下,全局数据库名中的数据库名称部分与SID相同或相似。 - **配置**:在Oracle 9i的安装过程中,用户需要输入全局数据库名称和...

    数据库名等名词解释

    数据库名、数据库实例名、数据库域名与全局数据库名以及数据库服务名是Oracle数据库系统中四个核心的名词,它们各自扮演着不同的角色,对于理解和管理Oracle数据库至关重要。 首先,数据库名(Database Name)是...

    Oracle中各名称介绍.docx

    Oracle数据库在设计和管理上涉及多个关键概念,包括数据库名、数据库实例名(SID)、数据库服务名和全局数据库名。这些概念对于理解和操作Oracle数据库至关重要。 首先,**数据库名**是安装或创建Oracle数据库时指定...

    Oracle数据库迁移方案

    2. **数据库实例名** (INSTANCE_NAME): 实例名是用户和操作系统交互时使用的标识。它与数据库名可以相同也可以不同,但在大多数情况下它们是一对一的关系。在Oracle并行服务器架构(如RAC)中,一个数据库名可能对应...

    ORACLE 中的几个重点概念

    但有时也容易被混淆,这些概念包括:数据库名(DB_NAME)、数据库实例名(INSTANCE_NAME)、操作系统环境变量ORACLE_SID、数据库服务名(SERVICE_NAME)、数据库域名(DB_DOMAIN)以及全局数据库名(GLOBAL_DB_NAME...

    sqlplusw 与 sqlplus登陆数据库的方法总结

    首先,需要了解 Oracle 数据库的基本概念,包括数据库名、数据库实例名、数据库域名和数据库服务名等。数据库名是数据库的标识,用参数 DB_NAME 表示。数据库实例名用于和操作系统进行联系,同样被写入参数文件:...

Global site tag (gtag.js) - Google Analytics