資料庫名(DB_NAME)、執行個體名(Instance_name)、以及作業系統環境變數(ORACLE_SID)
在ORACLE7、8資料庫中只有資料庫名(db_name)和資料庫執行個體名(instance_name)。在ORACLE8i、9i中出現了新的參
數,即資料庫網域名稱(db_domain)、服務名(service_name)、以及作業系統環境變數(ORACLE_SID)。這些都存在於同一個資料
庫中的標識,用於區分不同資料庫的參數。
一、什麼是資料庫名(db_name)?
資料庫名是用於區分資料的內部標識,是以二進位方式儲存於資料庫控制檔案中的參數,在資料安裝或建立之後將不得修改。資料庫安裝完成後,該參數被寫入資料庫參數檔案pfile中,格式如下:
.........
db_name="orcl" #(不允許修改)
db_domain=dbcenter.toys.com
instance_name=orcl
service_names=orcl.dbcenter.toys.com
control_file=(...............
.........
在每一個啟動並執行ORACLE8i資料庫中都有一個資料庫名(db_name),如果一個伺服器程式中建立了兩個資料庫,則有兩個資料庫名。其控制參資料分屬在不同的pfile中控制著相關的資料庫。
二、什麼是資料庫執行個體名(instance_name)
資料庫執行個體名則用於和作業系統之間的聯絡,用於對外部串連時使用。在作業系統中要取得與資料庫之間的互動,必須使用資料庫執行個體名。例如,要和某一個資料
庫server串連,就必須知道其資料庫執行個體名,只知道資料庫名是沒有用的,與資料庫名不同,在資料安裝或建立資料庫之後,執行個體名可以被修改。資料庫安裝
完成後,該執行個體名被寫入資料庫參數檔案pfile中,格式如下:
db_name="orcl" #(不允許修改)
db_domain=dbcenter.toys.com
instance_name=orcl #(可以修改,可以與db_name相同也可不同)
service_names=orcl.dbcenter.toys.com
control_file=(...............
.........
資料庫名與執行個體名之間的關係。
資料庫名與執行個體名之間的關係一般是一一對應關係,有一個資料庫名就有一個執行個體名,如果在一個伺服器中建立兩個資料庫,則有兩個資料庫名,兩個資料庫執行個體名,用兩個標識確定一個資料庫,使用者和執行個體相串連。
但在8i、9i的並行伺服器結構中,資料庫與執行個體之間不存在一一對應關係,而是一對多關聯性,(一個資料庫對應多個執行個體,同一時間內使用者只一個執行個體相聯絡,當某一執行個體出現故障,其它執行個體自動服務,以保證資料庫安全運行。)
三、作業系統環境變數(ORACLE_SID)
在實際中,對於資料庫執行個體名的描述有時使用執行個體名(instance_name)參數,有時使用ORACLE_SID參數。這兩個都是資料庫執行個體名,它們有什麼區別呢?(經常弄混)
(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)