前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle段收缩功能

Oracle段收缩功能

作者头像
Alfred Zhao
发布2022-05-06 14:39:19
8620
发布2022-05-06 14:39:19
举报

1. 了解段收缩

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

(1)压缩数据行,

(2)移动高水位线(HWM)。 因为重新定位HWM可能阻塞用户的DML操作,而存粹的收缩操作则不会产生这种影响。 操作期间会维护表上的所有索引。

2. 自动执行Segment Advisor

2.1 在OEM查看并设置

代码语言:javascript
复制
服务器 -> 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;
 /

3. 收缩段

**收缩段核心步骤:**

代码语言:javascript
复制
--启用行移动
 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

代码语言:javascript
复制
--创建表T3
 create table T3 (c1 varchar2(4000));

3.2 往T3插入1000行(使用大值),然后使用小值更新这些行

代码语言:javascript
复制
--往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

代码语言:javascript
复制
T3                                      8
 --使用小值更新这些行
 update t3 set c1='1';
 commit;
 --此时再次查询表T3大小是不变的

3.3 设置启动Segment Advisor作业

代码语言:javascript
复制
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;
 /

执行过程如下:

代码语言:javascript
复制
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

代码语言:javascript
复制
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

代码语言:javascript
复制
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 执行段收缩

代码语言:javascript
复制
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

代码语言:javascript
复制
T3                                  .0625

可以看到,T3表由8M大小成功收缩成0.0625M大小。至此,完成T3表的shrink操作。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-01-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 了解段收缩
  • 2. 自动执行Segment Advisor
  • 3. 收缩段
相关产品与服务
云顾问
云顾问(Tencent Cloud Smart Advisor)是一款提供可视化云架构IDE和多个ITOM领域垂直应用的云上治理平台,以“一个平台,多个应用”为产品理念,依托腾讯云海量运维专家经验,助您打造卓越架构,实现便捷、灵活的一站式云上治理。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档