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