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表碎片整理Oracle
- Oracle表段中的高水位線HWMOracle
- Sqlserver的表沒有高水位但是有碎片的概念,sqlserver表的碎片的檢視和整理方法SQLServer
- oracle 高水位線及如何有效的降低高水位線Oracle
- ORACLE 高水位線(HWM)Oracle
- oracle 回收高水位線Oracle
- Oracle 降低高水位線Oracle
- oracle回收高水位線Oracle
- oracle高水位線處理Oracle
- Oracle之降低高水位線Oracle
- oracle 高水位線詳解Oracle
- oracle的高水位線HWMOracle
- oracle的高水位線(HWM)Oracle
- Oracle資料表碎片整理Oracle
- 一、oracle 高水位線詳解Oracle
- 降低Oracle高水位線的方法Oracle
- Oracle的高水位線介紹Oracle
- Oracle資料庫表碎片整理Oracle資料庫
- ORACLE表空間的碎片整理Oracle
- Oracle表段中高水位線HWMOracle
- Oracle 高水位線的一點研究Oracle
- ORACLE高水位表的查詢方法Oracle
- Oracle 資料庫整理表碎片Oracle資料庫
- Oracle高水位Oracle
- oracle 碎片整理Oracle
- MySQL表碎片整理MySql
- ORACLE資料庫降低高水位線方法Oracle資料庫
- Oracle delete 高水位線處理問題Oracledelete
- Oracle高水位線(HWM)及效能優化Oracle優化
- 對Oracle高水位線的研究實踐Oracle
- Oracle 找出需要回收高水位的表Oracle
- Oracle 整理表碎片、釋放表的空間Oracle
- oracle回收高水位Oracle
- Oracle 高水位(HWM)Oracle
- oracle碎片整理方法Oracle
- Oracle案例10——HWM(高水位線)效能優化Oracle優化
- oracle11g表的高水位線hwm與dbms_space系列一Oracle
- oracle高水位問題Oracle