1. 了解段收縮
應用場景:如果對一張表頻繁執行插入、更新和刪除操作,時間長了可能會出現大量碎片,Oracle針對這種場景推出段收縮功能,以便減少碎片。 Oracle的段收縮執行兩項不同的任務:(1)壓縮數據行,(2)移動高水位線(HWM)。 因為重新定位HWM可能阻塞用戶的DML操作,而存粹的收縮操作則不會產生這種影響。 操作期間會維護表上的所有索引。2. 自動執行Segment Advisor
## 2.1 在OEM查看並設置 ## 服務器 -> Oracle Scheduler -> 自動維護任務 -> 配置,來啟用或禁用“段指導”任務,同時這里還可以設置“優化程序統計信息搜集”,“自動 SQL 優化” ## 2.2 使用SQL命令設置 ## ``` --禁用自動執行Segment Advisor BEGIN dbms_auto_task_admin.disable(client_name => 'auto space advisor', operation => NULL, window_name => NULL); END; /--啟用自動執行Segment Advisor
BEGIN
dbms_auto_task_admin.enable(client_name => 'auto space advisor', operation => NULL, window_name => NULL);
END;
/
<h1 id="3">3. 收縮段</h1>
**收縮段核心步驟:**
--啟用行移動
alter table T3 enable row movement;
--與大多數Oracle SQL命令不同,添加COMPACT關鍵字后,實際執行的操作不多反少,即HWM不移動
alter table T3 shrink space compact;
--去掉COMPACT關鍵字后,執行HWM移動
alter table T3 shrink space;
--禁用行移動
alter table T3 disable row movement;
**實驗:執行段分析和收縮操作**
## 3.1 創建表T3 ##
--創建表T3
create table T3 (c1 varchar2(4000));
## 3.2 往T3插入1000行(使用大值),然后使用小值更新這些行 ##
--往T3插入1000行(使用大值)
begin
for i in 1..1000 loop
insert into T3 select rpad(i,3900,'*') from dual;
end loop;
commit;
end;
/
--T3大小
select segment_name, BYTES/1024/1024 "MB" from user_segments where segment_name = 'T3';
SEGMENT_NAME MB
T3 8
--使用小值更新這些行
update t3 set c1='1';
commit;
--此時再次查詢表T3大小是不變的
## 3.3 設置啟動Segment Advisor作業 ##
variable task_id number
declare
name varchar2(100);
descr varchar2(500);
obj_id number;
begin
name := ''; --unique name
descr := 'Check T3 table';
dbms_advisor.create_task('Segment Advisor', :task_id, name, descr, null);
dbms_advisor.create_object(name, 'TABLE', 'JINGYU', 'T3', null, null, obj_id);
dbms_advisor.set_task_parameter(name, 'RECOMMEND_ALL', 'TRUE');
dbms_advisor.execute_task(name);
end;
/
執行過程如下:
SQL> conn jingyu/jingyu
Connected.
SQL> variable task_id number
SQL> declare
2 name varchar2(100);
3 descr varchar2(500);
4 obj_id number;
5 begin
6 name := ''; --unique name
7 descr := 'Check T3 table';
8 dbms_advisor.create_task('Segment Advisor', :task_id, name, descr, null);
9 dbms_advisor.create_object(name, 'TABLE', 'JINGYU', 'T3', null, null, obj_id);
10 dbms_advisor.set_task_parameter(name, 'RECOMMEND_ALL', 'TRUE');
11 dbms_advisor.execute_task(name);
12 end;
13 /
PL/SQL procedure successfully completed.
Elapsed: 00:00:02.01
SQL>
SQL>
SQL> print task_id
TASK_ID
1358
根據上面的TASK_ID查詢DBA_ADVISOR_FINDINGS
col owner for a20
col task_name for a20
col type for a20
select owner, task_id, task_name, type, message, more_info from dba_advisor_findings where task_id=1358;
OWNER TASK_ID TASK_NAME TYPE
MESSAGE
MORE_INFO
JINGYU 1358 TASK_1358 PROBLEM
The free space in the object is less than 10MB.
Allocated Space:8388608: Used Space:954000: Reclaimable Space :7434608:
## 3.4 執行段收縮 ##
alter table T3 enable row movement;
alter table T3 shrink space compact;
alter table T3 shrink space;
alter table T3 disable row movement;
--T3大小
select segment_name, BYTES/1024/1024 "MB" from user_segments where segment_name = 'T3';
SEGMENT_NAME MB
T3 .0625
可以看到,T3表由8M大小成功收縮成0.0625M大小。至此,完成T3表的shrink操作。