隨筆-314  評論-209  文章-0  trackbacks-0

          一、數據庫名

            數據庫名是數據庫的“身份證號碼”,用于標示一個數據庫。在參數文件中用DB_NAME表示。

            數據庫名是在安裝數據庫、創建新的數據庫、創建數據庫控制文件、修改數據庫結構、備份與恢復數據庫時都需要使用到的。

            如何查看數據庫名呢?方式有三:

            ·使用SQL語句:select name from v$database;

            ·使用show命令:show parameter db_name;

            ·查看參數文件:查看init.ora文件

            二、數據庫實例名:

            數據庫實例名是用于和操作系統進行聯系的標識,也就是說數據庫和操作系統之間的交互使用的是數據庫實例名。

            實例名也被寫入參數文件中,該參數為instance_name,在winnt平臺中,實例名同時也被寫入注冊表。

            數據庫名和實例名可以相同也可以不同。在一般情況下,數據庫名和實例名是一對一的關系,但如果在oracle并行服務器架構(即oracle實時應用集群)中,數據庫名和實例名是一對多的關系。

            如何查看當前數據庫實例名呢?方式有三:

            ·使用SQL語句:select instance_name from v$instance;

            ·使用show命令:show parameter instance

            ·查看參數文件:查看init.ora文件

            數據庫實例名與ORACLE_SID兩者都表示oracle實例,但是有區別的。instance_name是oracle數據庫參數。而ORACLE_SID是操作系統的環境變量。ORACLD_SID用于與操作系統交互,也就是說,從操作系統的角度訪問實例名,必須通過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建議用此種方法命令數據庫。該值是在創建數據庫是決定的,缺省值為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的并行環境中,一個數據庫對應多個實例,這樣就需要多個網絡服務名,設置繁瑣。為了方便并行環境中的設置,引進了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)。是客戶端程序訪問數據庫時所需要,屏蔽了客戶端如何連接到服務器端的細節,實現了數據庫的位置透明的特性。網絡服務名被記錄在tnsnames.ora文件中。

            網絡服務名是從客戶端的角度出發,當客戶端連接遠程數據庫或其他服務時,可以指定Net服務名。因此需要使用一個或多個命名方法將此Net服務名解析為連接數據庫或其他服務的連接描述符。

            通常選擇的是[本地]-將存儲在本地客戶機的tnsnames.ora文件中的網絡服務名解析為連接描述符。

            [Oracle Names]-由Oracle名字服務器提供為網絡上的每個Oracle Net服務提供解析方法

            [主機名]-通過TCP/IP環境中的主機別名連接到Oracle數據庫服務

            [Sun NIS]/[DCE CDS]-專用系統用的,在Windows 2000系統環境下不適用

            六、總結

            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 閱讀(547) 評論(2)  編輯  收藏 所屬分類: Oracle

          評論:
          # re: Oracle體系結構之-Oracle中各種名稱 2008-05-31 15:19 | xzc
          Db_name:對一個數據庫(Oracle database)的唯一標識,該數據庫為第一章講到的Oracle database。這種表示對于單個數據庫是足夠的,但是隨著由多個數據庫構成的分布式數據庫的普及,這種命令數據庫的方法給數據庫的管理造成一定的負擔,因為各個數據庫的名字可能一樣,造成管理上的混亂。為了解決這種情況,引入了Db_domain參數,這樣在數據庫的標識是由Db_name和Db_domain兩個參數共同決定的,避免了因為數據庫重名而造成管理上的混亂。這類似于互連網上的機器名的管理。我們將Db_name和Db_domain兩個參數用’.’連接起來,表示一個數據庫,并將該數據庫的名稱稱為Global_name,即它擴展了Db_name。Db_name參數只能由字母、數字、’_’、’#’、’$’組成,而且最多8個字符。

          Db_domain:定義一個數據庫所在的域,該域的命名同互聯網的’域’沒有任何關系,只是數據庫管理員為了更好的管理分布式數據庫而根據實際情況決定的。當然為了管理方便,可以將其等于互聯網的域。

          Global_name:對一個數據庫(Oracle database)的唯一標識,oracle建議用此種方法命令數據庫。該值是在創建數據庫是決定的,缺省值為Db_name. Db_domain。在以后對參數文件中Db_name與Db_domain參數的任何修改不影響Global_name的值,如果要修改Global_name,只能用ALTER DATABASE RENAME GLOBAL_NAME TO <db_name.db_domain>命令進行修改,然后修改相應參數。

          Service_name:該參數是oracle8i新引進的。在8i以前,我們用SID來表示標識數據庫的一個實例,但是在Oracle的并行環境中,一個數據庫對應多個實例,這樣就需要多個網絡服務名,設置繁瑣。為了方便并行環境中的設置,引進了Service_name參數,該參數對應一個數據庫,而不是一個實例,而且該參數有許多其它的好處。該參數的缺省值為Db_name. Db_domain,即等于Global_name。一個數據庫可以對應多個Service_name,以便實現更靈活的配置。該參數與SID沒有直接關系,即不必Service name 必須與SID一樣。

          Net service name:網絡服務名,又可以稱為數據庫別名(database alias)。是客戶端程序訪問數據庫時所需要,屏蔽了客戶端如何連接到服務器端的細節,實現了數據庫的位置透明的特性  回復  更多評論
            
          # re: Oracle體系結構之-Oracle中各種名稱 2008-05-31 15:20 | xzc
          select * from v$database;
          select * from v$instance;
          select * from v$parameter;  回復  更多評論
            
          主站蜘蛛池模板: 晋中市| 前郭尔| 沙坪坝区| 洪江市| 甘泉县| 周至县| 仪陇县| 萍乡市| 太白县| 龙南县| 南木林县| 蒙城县| 嘉黎县| 凤城市| 桂阳县| 元阳县| 镇宁| 杭锦后旗| 洱源县| 渭南市| 巴里| 集安市| 阿拉善右旗| 綦江县| 丰都县| 庆云县| 哈巴河县| 正宁县| 崇信县| 大名县| 华阴市| 松滋市| 玉山县| 疏勒县| 伊川县| 霸州市| 陇南市| 兴和县| 阆中市| 刚察县| 顺平县|