善用oracle表空間設計提公升資料庫效能。
oracle資料庫開創性地提出了表空間的設計理念,這為oracle資料庫的高效能做出了不可磨滅的貢獻。可以這麼說,oracle中很多優化都是基於表空間的設計理念而實現的。
典型應用一:控制使用者所占用的表空間配額
在一些大型的資料庫應用中,我們需要控制某個使用者或者某一組使用者其所占用的磁碟空間。這就好像在檔案伺服器中,需要為每個使用者設定磁碟配額一樣,以防止硬碟空間耗竭。所以,在資料庫中,我們也需要限制使用者所可以使用的磁碟空間大小。為了達到這個目的,我們就可以通過表空間來實現。
我們可以在oracle資料庫中,建立不同的表空間,為其設定最大的儲存容量,然後把使用者歸屬於這個表空間。如此的話,這個使用者的儲存容量,就受到這個表空間大小的限制。
典型應用二:控制資料庫所占用的磁碟空間
有時候,在oracle資料庫伺服器中,可能執行的不止乙個服務。除了資料庫伺服器外,可能還有郵件伺服器等應用系統伺服器。為此,就需要先對oracle資料庫的磁碟空間作個規劃,否則,當多個應用程式服務所占用的磁碟空間都無限增加時,最後可能導致各個服務都因為硬碟空間的耗竭而停止。所以,在同一臺伺服器上使用多個應用程式服務,我們往往需要先給他們進行磁碟空間的規劃和分配。各個服務都不能夠超過我們分配給他的最大限額,或者超過後及時的提醒我們。只有這樣,才能夠避免因為磁碟空間的耗竭而導致各種應用服務的崩潰。
典型應用三:靈活放置表空間,提高資料庫的輸入輸出效能
資料庫管理員還可以將不同型別的資料放置到不同的表空間中,這樣可以明顯提高資料庫輸入輸出效能,有利於資料的備份與恢復等管理工作。因為我們資料庫管理員在備份或者恢復資料的時候,可以按表空間來備份資料。如在設計乙個大型的分銷系統後台資料庫的時候,我們可以按省份建立表空間。與浙江省相關的資料檔案放置在浙江省的表空間中,北京發生業務記錄,則記錄在北京這個表空間中。如此,當浙江省的業務資料出現錯誤的時候,則直接還原浙江省的表空間即可。很明顯,這樣設計,當某個表空間中的資料出現錯誤需要恢復的時候,可以避免對其他表空間的影響。
另外,還可以對錶空間進行獨立備份。當資料庫容量比較大的時候,若一下子對整個資料庫進行備份,顯然會占用比較多的時間。雖然說oracle資料庫支援熱備份,但是在備份期間,會占用比較多的系統資源,從而造成資料庫效能的下降。為此,當資料庫容量比較大的時候,我們就需要進行設定多個表空間,然後規劃各個表空間的備份時間,從而可以提高整個資料庫的備份效率,降低備份對於資料庫正常執行的影響。
典型應用四:大表的排序操作
我們都知道,當表中的記錄比較多的時候,對他們進行查詢,速度會比較慢。第一次查詢成功後,若再對其進行第二次重新排序,仍然需要這麼多的時間。為此,我們在資料庫設計的時候,針對這種容量比較大的表物件,往往把它放在乙個獨立的表空間,以提高資料庫的效能。
典型應用五:日誌檔案與資料檔案分開放,提高資料庫安全性
預設情況下,日誌檔案與資料檔案存放在同一表空間。但是,這對於資料庫安全方面來說,不是很好。所以,我們在資料庫設計的過程中,往往喜歡把日誌檔案,特別是重做日誌檔案,放在乙個獨立的表空間中,然後把它存放在另外一塊硬碟上。如此的話,當存放資料檔案的硬碟出現故障時,能夠馬上通過存放在另乙個表空間的重做日誌檔案,對資料庫進行修復,以減少企業因為資料丟失所帶來的損失。
當然,表空間的優勢還不僅僅這些,企業對於資料庫的效能要求越高,或者資料庫容量越大,則表空間的優勢就會越大。
下面,我們就具體來看看oracle資料庫中表空間的處理方式,看其在效能與安全性方面是否有足夠的優勢與sql server資料庫抗衡。
在資料庫設計的時候,我們建議資料庫管理員按如下順序設定表空間。
第一步:建立表空間。
在設計資料庫的時候,首先需要設計表空間。我們需要考慮,是只建立乙個表空間呢,還是需要建立多個表空間,以及各個表空間的存放位置、磁碟限額等等。
到底設計多少個表空間合理,沒有統一的說法,這主要根據企業的實際需求去判斷。如企業需要對使用者進行磁碟限額控制的,則就需要根據使用者的數量來設定表空間。當企業的資料容量比較大,而其又對資料庫的效能有比較高的要求時,就需要根據不同型別的資料,設定不同的表空間,以提高其輸入輸出效能。
第二步:建立使用者,並制定使用者的預設表空間。
在建立使用者的時候,我們建議資料庫管理員要指定使用者的預設表空間。因為我們在利用create語句建立資料庫物件,如資料庫表的時候,其預設是儲存在資料庫的當前預設空間。若不指定使用者預設表空間的話,則使用者每次建立資料庫物件的時候,都要指定表空間,顯然,這並不是很合理。
另外要注意,不同的表空間有不同的許可權控制。使用者對於表空間a具有完全控制許可權,可能對於表空間b就只有查詢許可權,甚至連連線的許可權的都沒有。所以,合理為使用者配置表空間的訪問許可權,也是提高資料庫安全性的乙個方法。
Oracle資料庫設計提公升效能的五條法則
眾所周知,資料庫設計的好壞直接關係到資料庫執行的效率。根據筆者的經驗,對於提公升資料庫效能來說,合理的資料庫設計,比公升級伺服器的硬體配置,還要來的有效。但是,筆者無論是在跟同事合作,又或者是在論壇上跟相關同行交流的時候,總是會發現有些人有一些不好的資料庫設計習慣,影響了資料庫的效能,增加了資料庫管...
Oracle資料庫設計提公升效能的五條法則
眾所周知,資料庫設計的好壞直接關係到資料庫執行的效率。根據筆者的經驗,對於提公升資料庫效能來說,合理的資料庫設計,比公升級伺服器的硬體配置,還要來的有效。但是,筆者無論是在跟同事合作,又或者是在論壇上跟相關同行交流的時候,總是會發現有些人有一些不好的資料庫設計習慣,影響了資料庫的效能,增加了資料庫管...
認知設計 提公升學習體驗的藝術
認知設計 提公升學習體驗的藝術 基本資訊 原書名 design for how people learn 譯者 簡駕 叢書名 ui設計叢書 出版社 機械工業出版社 isbn 9787111388326 出版日期 2013 年4月 開本 16開 頁碼 1 版次 1 1 所屬分類 計算機 數碼 設計 u...