oracle表碎片以及整理(高水位線)
確定碎片程度
SELECT table_name,
ROUND ( (blocks * 8), 2) "高水位空間 k",
ROUND ( (num_rows * avg_row_len / 1024), 2) "真實使用空間 k",
ROUND ( (blocks * 10 / 100) * 8, 2) "預留空間(pctfree) k",
ROUND (
( blocks * 8
- (num_rows * avg_row_len / 1024)
- blocks * 8 * 10 / 100),
2)
"浪費空間 k"
FROM user_tables
WHERE temporary = 'N'
ORDER BY 5 DESC;
檢視錶上次收集統計資訊時間
select table_name,last_analyzed from dba_tables where owner = 'SCHEMA_NAME';
收集整個 Schema 中物件的統計資訊
SQL> exec dbms_stats.gather_schema_stats(ownname=>'SCHEMA_NAME');
-- 整理表,不影響DML操作
SQL> alter table TABLE_NAME enable ROW MOVEMENT;--啟動行移動功能
SQL> alter table TABLE_NAME shrink space compact; --只整理碎片 不回收空間
-- 重置高水位,此時不能有DML操作
SQL> alter table TABLE_NAME shrink space; --整理碎片並回收空間,並調整水位線。業務少時執行
SQL> alter table TABLE_NAME disable ROW MOVEMENT;--關閉行移動
shrink 的優勢:
不需要重建索引。
可以線上操作。
如果系統業務比較繁忙,
可以先執行shrink space compact重組資料,然後在業務不忙的時候再執行shrink space降低HWM釋放空閒資料塊。
SELECT table_name,
ROUND ( (blocks * 8), 2) "高水位空間 k",
ROUND ( (num_rows * avg_row_len / 1024), 2) "真實使用空間 k",
ROUND ( (blocks * 10 / 100) * 8, 2) "預留空間(pctfree) k",
ROUND (
( blocks * 8
- (num_rows * avg_row_len / 1024)
- blocks * 8 * 10 / 100),
2)
"浪費空間 k"
FROM user_tables
WHERE temporary = 'N'
ORDER BY 5 DESC;
檢視錶上次收集統計資訊時間
select table_name,last_analyzed from dba_tables where owner = 'SCHEMA_NAME';
收集整個 Schema 中物件的統計資訊
SQL> exec dbms_stats.gather_schema_stats(ownname=>'SCHEMA_NAME');
-- 整理表,不影響DML操作
SQL> alter table TABLE_NAME enable ROW MOVEMENT;--啟動行移動功能
SQL> alter table TABLE_NAME shrink space compact; --只整理碎片 不回收空間
-- 重置高水位,此時不能有DML操作
SQL> alter table TABLE_NAME shrink space; --整理碎片並回收空間,並調整水位線。業務少時執行
SQL> alter table TABLE_NAME disable ROW MOVEMENT;--關閉行移動
shrink 的優勢:
不需要重建索引。
可以線上操作。
如果系統業務比較繁忙,
可以先執行shrink space compact重組資料,然後在業務不忙的時候再執行shrink space降低HWM釋放空閒資料塊。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30345407/viewspace-2150310/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE 高水位線(HWM)Oracle
- Oracle資料表碎片整理Oracle
- Sqlserver的表沒有高水位但是有碎片的概念,sqlserver表的碎片的檢視和整理方法SQLServer
- oracle高水位線處理Oracle
- Oracle資料庫表碎片整理Oracle資料庫
- 一、oracle 高水位線詳解Oracle
- Oracle 資料庫整理表碎片Oracle資料庫
- ORACLE資料庫降低高水位線方法Oracle資料庫
- Oracle案例10——HWM(高水位線)效能優化Oracle優化
- MySQL表碎片整理MySql
- oracle 高水位分析處理Oracle
- Oracle資料庫管理——表資料庫高水位及shrink操作Oracle資料庫
- 驗證Oracle 10g線上整理碎片索引是否失效過程Oracle 10g索引
- Oracle 20c 新特性:Online SecureFiles Defragmentation 線上的 LOB 碎片整理OracleFragment
- 索引碎片整理索引
- ORACLE 如何診斷高水位爭用(enq: HW – contention)OracleENQ
- Oracle 高水位查詢和處理方法彙總Oracle
- 聊聊flink水位線
- oracle表空間的整理Oracle
- mysql之 OPTIMIZE TABLE整理碎片MySql
- Oracle資料庫高水位釋放——LOB欄位空間釋放Oracle資料庫
- windows10系統磁碟碎片整理在哪 win10如何開啟磁碟碎片整理WindowsWin10
- 關於高水位的知識
- flink 中的水位線(Watermark)
- 對oracle分割槽表的理解整理Oracle
- ORACLE常見檢視和表整理Oracle
- flink版本: 1.14.6 flink水位生成以及基於水位觸發視窗的計算
- 硬碟加速和磁碟碎片整理軟體硬碟
- MySQL碎片整理小節--例項演示MySql
- Oracle move和shrink釋放高水位空間Oracle
- Ooracle 高水位線(high water mask)在不同段管理模式下的推進Oracle模式
- MySQL的表碎片處理MySql
- win10系統無法整理磁碟碎片提示已由其它程式建立了計劃磁碟碎片整理的解決方法Win10
- Oracle左外連線、右外連線、完全外連線以及(+)號用法Oracle
- MySQL線上轉分割槽表(以及TiDB)MySqlTiDB
- java/android 做題中整理的碎片小貼士(4)JavaAndroid
- oracle資料庫檢視鎖表的sql語句整理Oracle資料庫SQL
- Oracle Database Scheduler整理OracleDatabase
- oracle建立臨時表空間和資料表空間以及刪除Oracle