博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle段收缩功能
阅读量:7005 次
发布时间:2019-06-27

本文共 3577 字,大约阅读时间需要 11 分钟。

1. 了解段收缩

应用场景:如果对一张表频繁执行插入、更新和删除操作,时间长了可能会出现大量碎片,Oracle针对这种场景推出段收缩功能,以便减少碎片。

Oracle的段收缩执行两项不同的任务:(1)压缩数据行,(2)移动高水位线(HWM)。
因为重新定位HWM可能阻塞用户的DML操作,而存粹的收缩操作则不会产生这种影响。
操作期间会维护表上的所有索引。

2. 自动执行Segment Advisor

2.1 在OEM查看并设置

服务器 -> Oracle Scheduler -> 自动维护任务 -> 配置,来启用或禁用“段指导”任务,同时这里还可以设置“优化程序统计信息搜集”,“自动 SQL 优化”

2.2 使用SQL命令设置

--禁用自动执行Segment AdvisorBEGINdbms_auto_task_admin.disable(client_name => 'auto space advisor', operation => NULL, window_name => NULL);END;/--启用自动执行Segment AdvisorBEGINdbms_auto_task_admin.enable(client_name => 'auto space advisor', operation => NULL, window_name => NULL);END;/

3. 收缩段

收缩段核心步骤:

--启用行移动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

--创建表T3create 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 numberdeclare  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/jingyuConnected.SQL> variable task_id numberSQL> 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.01SQL> SQL> SQL> print task_id   TASK_ID----------      1358

根据上面的TASK_ID查询DBA_ADVISOR_FINDINGS

col owner for a20col task_name for a20col type for a20select 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            PROBLEMThe 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操作。

转载地址:http://ptutl.baihongyu.com/

你可能感兴趣的文章