Oracle段收缩功能
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段收缩功能的更多相关文章
- 用mysql实现类似于oracle dblink的功能
用mysql实现类似于oracle dblink的功能 首先看看有没有federated 引擎. mysql> show engines; +------------+----------+ ...
- WordPress文章页添加展开/收缩功能
很多时候我们在WordPress上发布一些文章的时候里面都包含了很多的代码,我一般又不喜欢把代码压缩起来而喜欢让代码格式化显示,但是格式化显示通常会让文章内容看起来很多,不便于访问者浏览,所以今天就介 ...
- oracle修改审计功能
oracle修改审计功能 如果没有关闭审计功能,审计日志文件默认保存在位置为$ORACLE_BASE/admin/$ORACLE_SID/adump/ 关闭审计:alter system set au ...
- oracle导入导出功能
1.普通版:oracle导入导出功能:导出exp 用户名/密码@SID file=f:\xx.dmp owner=用户名 导入imp 用户名/密码@SID full=y file=f:\xx.dmp ...
- dhtmlxtree 节点 展开收缩:新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开、收缩状态)
dhtmlxtree 节点 展开收缩通常情况我们按 +- 就实现了 展开收缩 功能,为了方便我们新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开.收缩状态) tree = new dh ...
- Oracle EBS WMS功能介绍(二)
Oracle EBS WMS功能介绍(二) (版权声明,本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处.否则请与本人联系,违者必究) 出货物流逻辑主要包括 1. 打包.能够进 ...
- mysql和oracle的区别(功能性能、选择、使用它们时的sql等对比)
一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他se ...
- oracle数据库基础功能
一.oracle基本常用的数据类型 varchar(长度) 字符串char(长度) 字符number(x,y) x表示总位数 y表示保留小数点后几位数 eg面试题:number(5,3)最大的数是99 ...
- Oracle的AUTOTRACE功能
ORACLE9i在使用autotrace之前,需要作一些初始设置: 1.用sys用户运行脚本utlxplan.sql创建PLAN_TABLE表 脚本目录:(UNIX:$ORACLE_HOME/rdbm ...
随机推荐
- TPC-H生成.tbl文件导入postgresql数据库的坑
数据库project好好的不用主流的MySQL和Microsoft server而要求用听都没听过的postgresql (当然,可能你三个都没听过) 这里的坑主要是把生成的那八张.tbl的表导入pg ...
- int与string类型的转换
在SQL语句中 在JS中, (1) var x=100 a = x.toString() (2) var x=100; a = x +"" ...
- Linux 系统的初始化配置
1.零时配置网卡IP地址 2.配置永久生效IP地址 需要进如 cd /etc/sysconfig/network-scripts 找到网卡文件编辑 3.零时主机名的更改. 4.永久主机名的更 ...
- Weblogic反序列化漏洞补丁更新解决方案
Weblogic反序列化漏洞的解决方案基于网上给的方案有两种: 第一种方案如下 使用SerialKiller替换进行序列化操作的ObjectInputStream类; 在不影响业务的情况下,临时删除掉 ...
- TCP/IP, WebSocket 和 MQTT
按照OSI网络分层模型,IP是网络层协议,TCP是传输层协议,而HTTP和MQTT是应用层的协议.在这三者之间, TCP是HTTP和MQTT底层的协议.大家对HTTP很熟悉,这里简要介绍下MQTT.M ...
- 关于EF6的记录Sql语句 与 EntityFramework.Extend 的诟病
1.关于EF6的记录Sql语句,一个老生长谈的问题. 他生成的sql语句实在是烂,大家都这样说 2.EF6 更新删除不方便,没有批量操作.所以,有人出了EF6.Extend 大家用起来也很爽 基于以 ...
- iOS开发系列--视图切换
概述 在iOS开发中视图的切换是很频繁的,独立的视图应用在实际开发过程中并不常见,除非你的应用足够简单.在iOS开发中常用的视图切换有三种,今天我们将一一介绍: UITabBarController ...
- [Hadoop大数据]——Hive部署入门教程
Hive是为了解决hadoop中mapreduce编写困难,提供给熟悉sql的人使用的.只要你对SQL有一定的了解,就能通过Hive写出mapreduce的程序,而不需要去学习hadoop中的api. ...
- Atitit 代码复用的理解attilax总结
Atitit 代码复用的理解attilax总结 1.1. 继承1 1.1.1. 模式1:原型继承1 1.1.2. 模式2:复制所有属性进行继承 拷贝继承1 1.1.3. 模式3:混合(mix-in)1 ...
- 20个JS优化代码技巧
原文网址链接为:http://www.jstips.co/ .截取了一部分本人认为比较实用的技巧分享给大家.其中一小部分技巧为JS面向对象的写法,不宜一一列出.关于JS面向对象的写法可参考本人前几篇随 ...