一、數據庫名
數據庫名是數據庫的“身份證號碼”,用于標示一個數據庫。在參數文件中用DB_NAME表示。
數據庫名是在安裝數據庫、創(chuàng)建新的數據庫、創(chuàng)建數據庫控制文件、修改數據庫結構、備份與恢復數據庫時都需要使用到的。
如何查看數據庫名呢?方式有三:
·使用SQL語句:select name from v$database;
·使用show命令:show parameter db_name;
·查看參數文件:查看init.ora文件
二、數據庫實例名:
數據庫實例名是用于和操作系統(tǒng)進行聯系的標識,也就是說數據庫和操作系統(tǒng)之間的交互使用的是數據庫實例名。
實例名也被寫入參數文件中,該參數為instance_name,在winnt平臺中,實例名同時也被寫入注冊表。
數據庫名和實例名可以相同也可以不同。在一般情況下,數據庫名和實例名是一對一的關系,但如果在oracle并行服務器架構(即oracle實時應用集群)中,數據庫名和實例名是一對多的關系。
如何查看當前數據庫實例名呢?方式有三:
·使用SQL語句:select instance_name from v$instance;
·使用show命令:show parameter instance
·查看參數文件:查看init.ora文件
數據庫實例名與ORACLE_SID兩者都表示oracle實例,但是有區(qū)別的。instance_name是oracle數據庫參數。而ORACLE_SID是操作系統(tǒng)的環(huán)境變量。ORACLD_SID用于與操作系統(tǒng)交互,也就是說,從操作系統(tǒng)的角度訪問實例名,必須通過ORACLE_SID。
ORACLE_SID必須與instance_name的值一致。否則,你將會收到一個錯誤。在unix平臺,是“ORACLE not available”,在winnt平臺,是“TNS:協議適配器錯誤”。
三、數據庫域名與全局數據庫名
隨著由多個數據庫構成的分布式數據庫的普及,這種命令數據庫的方法給數據庫的管理造成一定的負擔,因為各個數據庫的名字可能一樣,造成管理上的混亂。
為了解決這種情況,引入了Db_domain參數,這樣在數據庫的標識是由Db_name(數據庫名)和 Db_domain(數據庫域名)兩個參數共同決定的,避免了因為數據庫重名而造成管理上的混亂。這類似于互連網上的機器名的管理。
我們將Db_name和 Db_domain兩個參數用‘.’連接起來,表示一個數據庫,并將該數據庫的名稱稱為Global_name(全局數據庫名),即它擴展了Db_name。Db_name參數只能由字母、數字、’_’、’#’、’$’組成,而且最多8個字符。
對一個網絡數據庫(Oracle database)的唯一標識,oracle建議用此種方法命令數據庫。該值是在創(chuàng)建數據庫是決定的,缺省值為Db_name. Db_domain。在以后對參數文件中Db_name與Db_domain參數的任何修改不影響Global_name的值,如果要修改 Global_name,只能用ALTER DATABASE RENAME GLOBAL_NAME TO 命令進行修改,然后修改相應參數。
如何查詢數據庫域名呢?方法有三:
·使用SQL命令:select value from v$parameter where name = ´db_domain´;
·使用show命令:show parameter domain
·查看參數文件:在參數文件中查詢。
四、數據庫服務名
該參數是oracle8i新引進的。在8i以前,我們用SID來表示標識數據庫的一個實例,但是在Oracle的并行環(huán)境中,一個數據庫對應多個實例,這樣就需要多個網絡服務名,設置繁瑣。為了方便并行環(huán)境中的設置,引進了Service_name參數。該參數對應一個數據庫,而不是一個實例。
該參數的缺省值為Db_name. Db_domain,即等于Global_name。如果數據庫有域名,則數據庫服務名就是全局數據庫名;否則,數據庫服務名與數據庫名相同。
如何查詢數據庫服務名呢?方法有三:
·使用SQL語句:select value from v$parameter where name = ´service_name´;
·使用show命令:show parameter service_name
·查看參數文件:在參數文件中查詢。
從oracle8i開如的oracle網絡組件,數據庫與客戶端的連接主機串使用數據庫服務名。之前用的是ORACLE_SID,即數據庫實例名。
五、網絡服務名
網絡服務名,又可以稱為數據庫別名(database alias)。是客戶端程序訪問數據庫時所需要,屏蔽了客戶端如何連接到服務器端的細節(jié),實現了數據庫的位置透明的特性。網絡服務名被記錄在tnsnames.ora文件中。
網絡服務名是從客戶端的角度出發(fā),當客戶端連接遠程數據庫或其他服務時,可以指定Net服務名。因此需要使用一個或多個命名方法將此Net服務名解析為連接數據庫或其他服務的連接描述符。
通常選擇的是[本地]-將存儲在本地客戶機的tnsnames.ora文件中的網絡服務名解析為連接描述符。
[Oracle Names]-由Oracle名字服務器提供為網絡上的每個Oracle Net服務提供解析方法
[主機名]-通過TCP/IP環(huán)境中的主機別名連接到Oracle數據庫服務
[Sun NIS]/[DCE CDS]-專用系統(tǒng)用的,在Windows 2000系統(tǒng)環(huán)境下不適用
六、總結
Oracle中各種命名的比較名稱查詢方式
名稱
|
查詢方式
|
DB_NAME |
select name from v$database |
INSTANCE_NAME |
select instance_name from v$instance |
ORACLE_SID |
值和INSTANCE_NAME相同 |
DB_DOMAIN |
select value from v$parameter where name="db_domain" |
GLOBAL_NAME |
DB_NAME.DB_DOMAIN |
SERVICE_NAME |
select value from v$parameter where name="service_name" |
NET_SERVICE_NAME |
檢查tnsnames.ora文件 |
posted on 2008-05-31 15:18
xzc 閱讀(544)
評論(2) 編輯 收藏 所屬分類:
Oracle