数据库名、实例名、数据库域名、全局数据库名、服务名
这是几个令非常多刚開始学习的人easy混淆的概念。相信非常多刚開始学习的人都与我一样被标题上这些个概念搞得一头雾水。我们如今就来把它们弄个明确。
一、数据库名
什么是数据库名?
数据库名就是一个数据库的标识,就像人的身份证号一样。他用參数DB_NAME表示,如果一台机器上装了多全数据库,那么每个数据库都有一个数据库名。在数据库安装或创建完毕之后,參数DB_NAME被写入參数文件之中。格式例如以下:
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,在winnt平台中,实例名同一时候也被写入注冊表。
数据库名和实例名能够同样也能够不同。
在普通情况下,数据库名和实例名是一对一的关系,但假设在oracle并行server架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。这一点在第一篇中已有图例说明。
查询当前数据库实例名
方法一:select instance_name from v$instance;
方法二:show parameter instance
方法三:在參数文件里查询。
数据库实例名与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:协议适配器错误”。
数据库实例名与网络连接
数据库实例名除了与操作系统交互外,还用于网络连接的oracleserver标识。当你配置oracle主机连接串的时候,就须要指定实例名。当然8i以后版本号的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。
三、数据库域名
什么是数据库域名?
在分布工数据库系统中,不同版本号的数据库server之间,不论执行的操作系统是unix或是windows,各server之间都能够通过数据库链路进行远程复制,数据库域名主要用于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网络组件,数据库与client的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名
创建Oracle数据库(以Oracle10g为例)
有两种创建数据库的方式,一种是以命令行脚本方式,即手动方式创建;还有一种是利用Oracle提供的数据库配置向导来创建。本篇主要介绍在Unix和Windows下以命令行脚本方式创建Oracle数据库。
一个完整的数据库系统,应包含一个物理结构、一个逻辑结构、一个内存结构和一个进程结构,假设要创建一个新的数据库,则这些结构都必须完整的建立起来。
一、在Unix下创建数据库
1.确定数据库名、数据库实例名和服务名
关于数据库名、数据库实例名和服务名,我之前有专门用一篇来具体介绍。这里就不再说明了。
2.创建參数文件
參数文件非常确定了数据库的整体结构。Oracle10g有两种參数文件,一个是文本參数文件,一种是server參数文件。在创建数据库时先创建文本參数文件,
在数据库创建后,能够由文件參数文件创建server參数文件。文本參数文件的取名方式为initORACLE_SID.ora,当中,ORACLE_SID是
数据库实例名。其名称及路径为:
/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.ora
当中,DB_NAME为数据库名。所以,应创建一个以之命名的文件夹,并将文本參数文件存放在上述文件夹中。如果新创建的数据库名为MYORACLE,SID与数据库名一致。则上述文件夹实际为:
/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.ora
1)參数文件的介绍
參数文件决定着数据库的整体结构,用于设置数据库的近260个系统參数。以下分类别说明一下各參数的作用,关于參数的具体使用说明请參考Oracle官方參考文档。
a.数据库标识类參数DB_NAME: 数据库名,此參数在创建数据前决定,数据库创建后改动时,必须建控制文件
DB_DOMAIN: 数据库域名ÿ