關於排序、sort_area_size、臨時表空間(轉)
關於排序、sort_area_size、臨時表空間
簡單陳述一下:
針對每個session,排序首先會使用sort_area_size ,如果不足則會使用臨時表空間。但這裡面又到底是怎麼一個過程呢?下面闡述一下,也許對大家有用處(如果有什麼不清楚或者不恰當的地方歡迎大家探討)
假設sort_area_size = 100k,正好能盛下100條記錄進行排序
當排序記錄小於等於100條,ok,所有排序在記憶體中進行,很快
但若超過100條,則會使用臨時表空間(利用磁碟進行)
我們選取一個臨界值來說明,假設需要排序的記錄有10010條
這個時候我們進行的排序會分為101組進行
每讀100條進行一次小組排序,然後寫入磁碟,第101組只有10條,排序後也寫入磁碟
這是進行第二次排序,這次排序將在前100小組裡面各抽取一條進行排序。《按照我個人的猜測,應該是排好後每寫入一條入磁碟則將該記錄所在小組重新抽取一條出來進行排序(這時是有序記錄組裡面所以很快)》。當這個過程完成後,這時所需要的磁碟空間大約為 實際記錄儲存空間的2倍(這也是多數書上提到的排序空間大約是記錄空間的2倍的原因)
由於還剩下10條記錄,於是這10條記錄需要跟前面排序的10000條記錄進行排序合併,這個代價也是相當大的!
所以,我們通常推薦,假如你需要排序的記錄最大為100萬條,則sort_area_size最小要能裝下1000條,否則如上面的例子,那多餘的10條,僅僅10條將會帶來巨大的代價!
如果,設定的極度不合理的情況下,排序記錄達到了 sort_area_size所能容納的三次方以上,比如上面例子中排序需要100萬記錄
那麼同樣的,重複這個過程,當每一萬條記錄如上排序後,再如上從這100小組(每組10000條記錄)各抽一條進行排序……
在這個過程中,磁碟的消耗和時間的代價大家都應該有個感性認識了
所以,我們建議: sprt_area_size 所能容納記錄數至少大於排序記錄數的 平方根
針對每個session,排序首先會使用sort_area_size ,如果不足則會使用臨時表空間。但這裡面又到底是怎麼一個過程呢?下面闡述一下,也許對大家有用處(如果有什麼不清楚或者不恰當的地方歡迎大家探討)
假設sort_area_size = 100k,正好能盛下100條記錄進行排序
當排序記錄小於等於100條,ok,所有排序在記憶體中進行,很快
但若超過100條,則會使用臨時表空間(利用磁碟進行)
我們選取一個臨界值來說明,假設需要排序的記錄有10010條
這個時候我們進行的排序會分為101組進行
每讀100條進行一次小組排序,然後寫入磁碟,第101組只有10條,排序後也寫入磁碟
這是進行第二次排序,這次排序將在前100小組裡面各抽取一條進行排序。《按照我個人的猜測,應該是排好後每寫入一條入磁碟則將該記錄所在小組重新抽取一條出來進行排序(這時是有序記錄組裡面所以很快)》。當這個過程完成後,這時所需要的磁碟空間大約為 實際記錄儲存空間的2倍(這也是多數書上提到的排序空間大約是記錄空間的2倍的原因)
由於還剩下10條記錄,於是這10條記錄需要跟前面排序的10000條記錄進行排序合併,這個代價也是相當大的!
所以,我們通常推薦,假如你需要排序的記錄最大為100萬條,則sort_area_size最小要能裝下1000條,否則如上面的例子,那多餘的10條,僅僅10條將會帶來巨大的代價!
如果,設定的極度不合理的情況下,排序記錄達到了 sort_area_size所能容納的三次方以上,比如上面例子中排序需要100萬記錄
那麼同樣的,重複這個過程,當每一萬條記錄如上排序後,再如上從這100小組(每組10000條記錄)各抽一條進行排序……
在這個過程中,磁碟的消耗和時間的代價大家都應該有個感性認識了
所以,我們建議: sprt_area_size 所能容納記錄數至少大於排序記錄數的 平方根
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12801008/viewspace-607636/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle臨時表空間相關Oracle
- oracle 臨時表空間Oracle
- oracle臨時表空間Oracle
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- 臨時表空間temporary tablespace相關操作
- 批量處理時臨時增加回滾表空間臨時表空間檔案
- 臨時表空間的建立、刪除,設定預設臨時表空間
- mysql臨時表,臨時表空間,ibtmp1表空間暴增原因初探MySql
- Oracle 臨時表空間概念Oracle
- oracle臨時表空間組Oracle
- oracle的臨時表空間Oracle
- Oracle Temp 臨時表空間Oracle
- 關於移動臨時表空間檔案位置的問題
- 【臨時表空間組】臨時表空間組的建立、維護及應用
- 【儲存管理】建立臨時表空間組、建立臨時表空間組及使用
- 【實驗】重建臨時表空間解決臨時表空間過大問題
- 【臨時表空間】11g中使用 SHRINK方法縮小臨時表空間和臨時檔案
- 排序sort area 記憶體不足會用到臨時表空間排序記憶體
- 12C關於CDB、PDB 臨時temp表空間的總結
- 【臨時表空間】11g中使用 SHRINK方法縮小臨時表空間和臨時檔案(續)
- MySQL InnoDB臨時表空間配置MySql
- Oracle TEMP臨時表空間概念Oracle
- Oracle 臨時表空間的概念Oracle
- 臨時表空間操作總結
- ORACLE臨時表空間總結Oracle
- oracle 重建臨時表空間 tempfileOracle
- 刪掉Oracle臨時表空間Oracle
- ORACLE臨時表空間的清理Oracle
- oracle 表空間,臨時表空間使用率查詢Oracle
- Oracle修改預設表空間和預設臨時表空間Oracle
- 臨時表空間的空間使用情況查詢
- Oracle Temp臨時表空間處理Oracle
- ORACLE預設的臨時表空間Oracle
- oracle的臨時表空間temporary tablespaceOracle
- oracle清理和重建臨時表空間Oracle
- MySQL 5.7 新特性 共享臨時表空間及臨時表改進MySql
- 轉:Oracle 臨時表空間過大問題解決Oracle
- 臨時表空間和回滾表空間使用率查詢