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操作。

Oracle段收缩功能的更多相关文章

  1. 用mysql实现类似于oracle dblink的功能

      用mysql实现类似于oracle dblink的功能 首先看看有没有federated 引擎. mysql> show engines; +------------+----------+ ...

  2. WordPress文章页添加展开/收缩功能

    很多时候我们在WordPress上发布一些文章的时候里面都包含了很多的代码,我一般又不喜欢把代码压缩起来而喜欢让代码格式化显示,但是格式化显示通常会让文章内容看起来很多,不便于访问者浏览,所以今天就介 ...

  3. oracle修改审计功能

    oracle修改审计功能 如果没有关闭审计功能,审计日志文件默认保存在位置为$ORACLE_BASE/admin/$ORACLE_SID/adump/ 关闭审计:alter system set au ...

  4. oracle导入导出功能

    1.普通版:oracle导入导出功能:导出exp 用户名/密码@SID file=f:\xx.dmp owner=用户名 导入imp 用户名/密码@SID full=y file=f:\xx.dmp ...

  5. dhtmlxtree 节点 展开收缩:新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开、收缩状态)

    dhtmlxtree 节点 展开收缩通常情况我们按 +- 就实现了 展开收缩 功能,为了方便我们新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开.收缩状态) tree = new dh ...

  6. Oracle EBS WMS功能介绍(二)

    Oracle EBS WMS功能介绍(二) (版权声明,本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处.否则请与本人联系,违者必究) 出货物流逻辑主要包括 1.      打包.能够进 ...

  7. mysql和oracle的区别(功能性能、选择、使用它们时的sql等对比)

    一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他se ...

  8. oracle数据库基础功能

    一.oracle基本常用的数据类型 varchar(长度) 字符串char(长度) 字符number(x,y) x表示总位数 y表示保留小数点后几位数 eg面试题:number(5,3)最大的数是99 ...

  9. Oracle的AUTOTRACE功能

    ORACLE9i在使用autotrace之前,需要作一些初始设置: 1.用sys用户运行脚本utlxplan.sql创建PLAN_TABLE表 脚本目录:(UNIX:$ORACLE_HOME/rdbm ...

随机推荐

  1. C代码实现数组

    直接上代码,没有什么说的 # include <stdio.h> # include <malloc.h> # include <stdlib.h> //用C实现数 ...

  2. 电容参数:X5R,X7R,Y5V,COG 详解

    电容参数:X5R,X7R,Y5V,COG 详解 文章来源:http://www.hzlitai.com.cn/article/ARM9-article/cphard/1777.html 仅供分享学习~ ...

  3. php与js中函数参数的默认值设置

    php函数参数默认值设置: <?phpfunction test($val=3){   echo $val."<br/>";}test(11);test();?& ...

  4. android——自定义listView

    都知道微信主机面 有个界面会一行一一行的聊天记录,那个效果就可以用listview来实现(当然这只是其中的一种) listView是一种比较常见的组件它用来展示列的view,它是根据数据的长度来显示数 ...

  5. Permission denied user=hadoop access=WRITE inode=root rootsupergroup rwxr

    有段时间没有写了,反正我写的都是跟流水账一样.不为别人看,当然,其中也记录了很多我踩过的坑,可能也能给别人提个醒.最重要的是:这是我学习的记忆 上面的错误是由于我将reducer的输出目录设置在hdf ...

  6. 华为oj 刷题记录之合唱团

    华为OJ-合唱队 描述 计算最少出列多少位同学,使得剩下的同学排成合唱队形 说明: N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队 ...

  7. .net 下新版highcharts本地导出图片bug处理

    最近公司要用到highcharts这个插件来生成图表,所以我花了点时间研究了下. 现在最新的版本是3.0.2,这js插件居多优点就不比多说了,demo官网上也很详细.但是优点不爽的地方是,导出图片这个 ...

  8. C#_技巧:.net下C++调用C#的dll

    C#编译一个dll,比如命名空间为Csharp,里面有个类A,字段x,产生一个Csharp.dll C++ 配置,让C++支持CLR C++调用方法: #include <iostream> ...

  9. [实践] Android5.1.1源码 - 让某个APP以解释执行模式运行

    [实践] Android5.1.1源码 - 让某个APP以解释执行模式运行   作者:寻禹@阿里聚安全 前言 本文的实践修改了Android5.1.1的源码. 本文只简单的讲了一下原理.在“实践”一节 ...

  10. 图片拾取器-PicPicker

    最近报名参加了360前端星计划,想当一名前端实习生,学习更多更流行的前端知识.然后需要完成一个作业,才能进培训,进了培训还得看运气才能留下,流程不少.书归正传,请看: 课后作业题目 请从下面两个题目中 ...