oracle收缩表和表空间
segment shrink分为两个阶段:
1)、数据重组(compact):通过一系列insert、delete操作,将数据尽量排列在段的前面。在这个过程中需要在表上加RX锁,即只在需要移动的行上加锁。由于涉及到rowid的改变,需要enable row movement.同时要disable基于rowid的trigger,这一过程对业务影响比较小。
2)、HWM调整:第二阶段是调整HWM位置,释放空闲数据块。此过程需要在表上加X锁,会造成表上的所有DML语句阻塞。在业务特别繁忙的系统上可能造成比较大的影响。
shrink space 语句两个阶段都执行。
shrink space compact 只执行第一个阶段。
如果系统业务比较繁忙,可以先执行shrink space compact重组数据,然后在业务不忙的时候再执行shrink space降低HWM释放空闲数据块。
shrink必须开启行迁移功能。
alter table table_name enable row movement;
--收集t1表统计信息,并查询t1表水位线
exec DBMS_STATS.GATHER_TABLE_STATS('APP', 'T1', method_opt => 'for all indexed columns',cascade=>TRUE);
select TABLE_NAME,TABLESPACE_NAME,NUM_ROWS,BLOCKS from dba_tables where table_name='T1';
T1CC15000247
--插入数据
insert into app.t1 (select * from EZC3_APPLY.CTV_SDZQZ);
commit;
T1CC115000688
--删除数据
select count(*) from app.t1; --15000
delete from app.t1 where ryxb='1';
select count(*) from app.t1; --6315
--再次查看水位线
exec DBMS_STATS.GATHER_TABLE_STATS('APP', 'T1', method_opt => 'for all indexed columns',cascade=>TRUE);
select TABLE_NAME,TABLESPACE_NAME,NUM_ROWS,BLOCKS from dba_tables where table_name='T1';
T1CC16315688(块没变化)
--开启t1表行移动,并且开始收缩表
alter table app.t1 enable row movement;
alter table app.t1 shrink space compact;
alter table app.t1 shrink space cascade;
--再次查看水位线
exec DBMS_STATS.GATHER_TABLE_STATS('APP', 'T1', method_opt => 'for all indexed columns',cascade=>TRUE);
select TABLE_NAME,TABLESPACE_NAME,NUM_ROWS,BLOCKS from dba_tables where table_name='T1';
T1CC16315279 (存储块减少)
--插入数据增大表空间
begin
for i in 1 .. 1000
loop
insert into app.t1 (select * from EZC3_APPLY.CTV_SDZQZ);
end loop;
commit;
end; select * from dba_data_files where tablespace_name='CC1';
--现在文件大小
[oracle@deam orcl]$ du -sh cc*
613M cc1.dbf
605M cc2.dbf
--删除数据,收缩表
delete from app.t1;
alter table app.t1 enable row movement;
alter table app.t1 shrink space compact;
alter table app.t1 shrink space cascade;
--再次查看水位线
exec DBMS_STATS.GATHER_TABLE_STATS('APP', 'T1', method_opt => 'for all indexed columns',cascade=>TRUE);
select TABLE_NAME,TABLESPACE_NAME,NUM_ROWS,BLOCKS from dba_tables where table_name='T1';
--收缩表空间
ALTER DATABASE DATAFILE '/u01/app/oracle/oradata/orcl/cc1.dbf' RESIZE 30M;
ALTER DATABASE DATAFILE '/u01/app/oracle/oradata/orcl/cc2.dbf' RESIZE 30M;
--收缩后数据文件大小
[oracle@deam orcl]$ du -sh cc*
31M cc1.dbf
31M cc2.dbf
oracle收缩表和表空间的更多相关文章
- ORACLE 收缩表空间的数据文件
http://blog.itpub.net/29345367/viewspace-1816427/ 方法一: 在实际的应用中经常会遇到TRUNCATE或者DELETE表中的数据后发现表空间并没有将空间 ...
- Oracle收缩表空间
可以使用 alter database datafile 'file path...' resize xM 的命令来缩小数据文件. SELECT 'alter database datafile '' ...
- Oracle 执行报错表空间或临时表空间不足,降低水位线方法
Oracle 执行语句插入临时表报表空间不足,在增加表空间到最大后依然报错,经分析应该为创建的临时表水位线未清除导致,查询降低水位线方法如下: 原文地址:http://blog.itpub.net/2 ...
- oracle之二表和表空间的关系
表和表空间的关系 建一个使用缺省值的表空间SQL> create tablespace a datafile '/u01/data/urpdb/a01.dbf' size 10m; 利用orac ...
- Oracle学习笔记八 表空间
表空间 表空间是一个或多个数据文件的集合,所有的数据对象都存放在指定的表空间中,但主要存放的是表, 所以称作表空间 . 分区表 当表中的数据量不断增大,查询数据的速度就会变慢,应用程序的性能就会下 ...
- Oracle常用操作——创建表空间、临时表空间、创建表分区、创建索引、锁表处理
摘要:Oracle数据库的库表常用操作:创建与添加表空间.临时表空间.创建表分区.创建索引.锁表处理 1.表空间 ■ 详细查看表空间使用状况,包括总大小,使用空间,使用率,剩余空间 --详细查看表空 ...
- ORACLE修改用户表所属表空间的步骤
ORACLE修改用户表所属表空间的步骤 使用脚本进行修改.据目前所了解,正长情况下需要修改表的空间和表的索引的空间,如果涉及到BOLB字段的表,修改的方式又不一样了!正常情况下的修改脚本:1.修改表的 ...
- 实例讲解Oracle数据库设置默认表空间问题
实例讲解Oracle数据库设置默认表空间问题 实例讲解Oracle数据库设置默认表空间问题,阅读实例讲解Oracle数据库设置默认表空间问题,DBA们经常会遇到一个这样令人头疼的问题:不知道谁在O ...
- (转)Linux下Oracle启动、建立表空间、用户、授权、数据库导入导出
Linux系列 启动1.启动数据库实例,分为两步:第一步,启动监听:第二步,启动数据库实例. 1.1进入到sqlplus启动实例 [oracle@redhat ~]$ su - oracle ...
- Oracle数据库之创建表空间与用户
Oracle数据库之创建表空间与用户 一.创建表空间 基本语法表述: CREATE TABLESPACE tablespace_name [DATAFILE datafile_spec1 [,data ...
随机推荐
- 使用idea进行gitee代码管理
目录 1.在idea插件市场安装gitee插件 2.把本地仓库的release分支上的代码合到dev分支上 3.把本地dev分支上的代码合到远程dev分支上去 1.在idea插件市场安装gitee插件 ...
- [R语言] 基于R语言实现环状条形图的绘制
环状条形图(Circular barplot)是条形图的变体,图如其名,环状条形图在视觉上很吸引人,但也必须小心使用,因为环状条形图使用的是极坐标系而不是笛卡尔坐标系,每一个类别不共享相同的Y轴.环状 ...
- [编程基础] Python lambda函数总结
Python lambda函数教程展示了如何在Python中创建匿名函数.Python中的匿名函数是使用lambda关键字创建的. 文章目录 1 介绍 1.1 简单使用 1.2 Python lamb ...
- SpringBoot+Mybatis-plus整合easyExcel批量导入Excel到数据库+导出Excel
一.前言 今天小编带大家一起整合一下easyExcel,之所以用这个,是因为easyExcel性能比较好,不会报OOM! 市面上常见的导入导出Excel分为三种: hutool easyExcel p ...
- [Leetcode]旋转链表
题目 代码 /** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * Li ...
- vertica 7.0 使用kafka
config.propertiesclient.id设置为主机名或ip auto.offset.reset=smallest client.id=qas 设置环境变量 kafka_config=&qu ...
- 计组Review1
1GB的内存,它是以字节编址的,假设内存地址为32位,128KB的高速缓存.现在有一个数据位于0x123456(字节编址),会映射到那些不同情形的内存单元上,还有TAG和总缓存大小. 1. 直接映射, ...
- angularIonic CLI环境搭建安装以及栅格响应式布局
- Android原生集成JPush SDK
因为小黑是一名Unity开发,所以Android Studio上有写的不对的地方请大佬们指出,再集成的时候,有问题的或者疑问的也可以直接提出. 目录 使用版本: 接入JPush SDK 一:下载JPu ...
- 结对项目总结 -- 基于Qt开发的win10桌面应用
担任角色 在这次结对项目中,由于采用了我的个人项目作为参考,所以我继续担任后端开发的角色. 开发环境 前端采用Qt Creator4.13.2 (Community) 后端采用C++ 如何复用个人项目 ...