当前位置:  数据库>oracle

Oracle段收缩功能

    来源: 互联网  发布时间:2017-06-21

    本文导语: 1. 了解段收缩 应用场景:如果对一张表频繁执行插入、更新和删除操作,时间长了可能会出现大量碎片,Oracle针对这种场景推出段收缩功能,以便减少碎片。Oracle的段收缩执行两项不同的任务:(1)压缩数据行,(2)移动高水位线...

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;
/
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
--创建表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操作。


    
 
 

您可能感兴趣的文章:

  • 请问在红旗Linux多功能服务器版上(不是数据库服务器版)能否正常安装使用Oracle?红旗Linux数据库服务器版要比红旗Linux多功能服务器版贵
  • MySQL实现类似Oracle中的decode()函数的功能
  • Oracle SQL中实现indexOf和lastIndexOf功能的思路及代码
  • oracle的plsql里有没有位操作的功能
  • 怎么写一个Shell来执行这样的功能,访问Oracle数据库,然后执行一个SQL脚本,生成一个文件。急!
  • Oracle数据库中分区功能详解
  • Oracle11g备份和恢复功能的提高
  • 细化解析Oracle 10g STATSPACK的新功能
  • Oracle数据库后台进程的功能分析
  • Oracle 11G闪回数据归档新功能详述
  • Oracle备份功能比较
  • java/j2ee iis7站长之家
  • 利用导出/导入功能实现重新组织Oracle数据库表空间
  • Oracle 数据库闪回功能设置出现ORA-19809和ORA-19804错误
  • JAVA简单链接Oracle数据库 注册和登陆功能的实现代码
  • Oracle SecureFile的功能第1/4页
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3