典型應用一:控制用戶所占用的表空間配額。
在一些大型的數據庫應用中,我們需要控制某個用戶或者某一組用戶其所占用的磁盤空間。這就好像在文件服務器中,需要為每個用戶設置磁盤配額一樣,以防止硬盤空間耗竭。所以,在數據庫中,我們也需要限制用戶所可以使用的磁盤空間大小。為了達到這個目的,我們就可以通過表空間來實現。
我們可以在Oracle數據庫中,建立不同的表空間,為其設置最大的存儲容量,然后把用戶歸屬于這個表空間。如此的話,這個用戶的存儲容量,就受到這個表空間大小的限制。
典型應用二:控制數據庫所占用的磁盤空間。
有時候,在Oracle數據庫服務器中,可能運行的不止一個服務。除了數據庫服務器外,可能還有郵件服務器等應用系統服務器。為此,就需要先對Oracle數據庫的磁盤空間作個規(guī)劃,否則,當多個應用程序服務所占用的磁盤空間都無限增加時,最后可能導致各個服務都因為硬盤空間的耗竭而停止。所以,在同一臺服務器上使用多個應用程序服務,我們往往需要先給他們進行磁盤空間的規(guī)劃和分配。各個服務都不能夠超過我們分配給他的最大限額,或者超過后及時的提醒我們。只有這樣,才能夠避免因為磁盤空間的耗竭而導致各種應用服務的崩潰。
典型應用三:靈活放置表空間,提高數據庫的輸入輸出性能。
數據庫管理員還可以將不同類型的數據放置到不同的表空間中,這樣可以明顯提高數據庫輸入輸出性能,有利于數據的備份與恢復等管理工作。因為我們數據庫管理員在備份或者恢復數據的時候,可以按表空間來備份數據。如在設計一個大型的分銷系統后臺數據庫的時候,我們可以按省份建立表空間。與浙江省相關的數據文件放置在浙江省的表空間中,北京發(fā)生業(yè)務記錄,則記錄在北京這個表空間中。如此,當浙江省的業(yè)務數據出現錯誤的時候,則直接還原浙江省的表空間即可。很明顯,這樣設計,當某個表空間中的數據出現錯誤需要恢復的時候,可以避免對其他表空間的影響。
另外,還可以對表空間進行獨立備份。當數據庫容量比較大的時候,若一下子對整個數據庫進行備份,顯然會占用比較多的時間。雖然說Oracle數據庫支持熱備份,但是在備份期間,會占用比較多的系統資源,從而造成數據庫性能的下降。為此,當數據庫容量比較大的時候,我們就需要進行設置多個表空間,然后規(guī)劃各個表空間的備份時間,從而可以提高整個數據庫的備份效率,降低備份對于數據庫正常運行的影響。
典型應用四:大表的排序操作。
我們都知道,當表中的記錄比較多的時候,對他們進行查詢,速度會比較慢。第一次查詢成功后,若再對其進行第二次重新排序,仍然需要這么多的時間。為此,我們在數據庫設計的時候,針對這種容量比較大的表對象,往往把它放在一個獨立的表空間,以提高數據庫的性能。
典型應用五:日志文件與數據文件分開放,提高數據庫安全性。