在向大家詳細介紹Oracle擴展之前,首先讓大家了解下pctfree和pctused存儲參數,然後全面介紹Oracle擴展,希望對大家有用。以下的一些規則是用來設置freelists,freelistgroups,pctfree和pctused存儲參數的。你也知道,pctused和pctfree的值是可以很容易地通過alter table命令修改的,一個好的DBA應該知道如何設置這些參數的最佳值。
有效地使用空間和高性能之間是有矛盾的,而表格的存儲參數就是控制這個方面的矛盾:
◆對於需要有效地重新使用空間,可以設置一個高的pctused值,不過副作用是需要額外的I/O。一個高的pctused值意味著相對滿的塊都會放到freelist中。因此,這些塊在再次滿之前只可以接受幾行記錄,從而導致更多的I/O。
◆追求高性能的話,可以將pctused設置為一個低的值,這意味著Oracle不會將數據塊放到freelists中直到它幾乎是空的。
那麼塊將可以在滿之前接收更多的行,因此可以減少插入操作的I/O。要記住Oracle擴展新塊的性能要比重新使用現有的塊高。Oracle擴展一個表比管理freelists消耗更少的資源。
讓我們來回顧一下設置對象存儲參數的一些常見規則:
◆經常將pctused設置為可以接收一條新行。對於不能接受一行的free blocks對於我們來說是沒有用的。如果這樣做,將會令Oracle的性能變慢,因為Oracle擴展表來得到一個空的塊之前,企圖讀取5個“dead”的free block 。
◆表格中chained rows的出現意味著pctfree太低或者是db_block_size太少。在很多情況下,RAW和LONG RAW列都很巨大,以至超過了Oracle的最大塊的大小,這時chained rows是不可以避免的。
◆如果一個表有同時插入的SQL語句,那麼它需要有同時刪除的語句。運行單一個一個清除的工作將會把全部的空閒塊放到一個freelist中,而沒有其它包含有任何空閒塊的freelists出現。
◆freelist參數應該設置為表格同時更新的最大值。例如,如果在任何時候,某個表最多有20個用戶執行插入的操作,那麼該表的參數應該設置為freelists=20。
應記住的是freelist groups參數的值只是對於Oracle Parallel Server和Real Application Clusters才是有用的。對於這類Oracle,freelist groups應該設置為訪問該表格的Oracle Parallel Server實例的數目。