如何检查oracle表或索引可回收空间

  对表进行大量删除后,可能会有很多空闲空间可以回收,相关计算方法参考如下:

  更新统计信息

  Analyze table compute statistics ;

  计算碎片空间

  SELECT TABLE_NAME , (BLOCKS *8192 / 1024/1024 ) - (NUM_ROWS*AVG_ROW_LEN/1024/1024)

  "Data lower than HWM in MB" FROM DBA_TABLES WHERE UPPER(owner) =UPPER('&OWNER') order by 2 desc;

  ANALYZE TABLE big_emp1 ESTIMATE STATISTICS;

  SELECT table_name,num_rows,blocks,empty_blocks

  FROM user_tables

  WHERE table_name='BIG_EMP1';

  SELECT COUNT (DISTINCT

  DBMS_ROWID.ROWID_BLOCK_NUMBER(rowid)||

  DBMS_ROWID.ROWID_RELATIVE_FNO(rowid)) "Used"

  FROM big_emp1;

  SELECT segment_name,segment_type,blocks

  FROM dba_segments

  WHERE segment_name='BIG_EMP1';

  对于索引

  校验结构

  analyze index validate structure;

  检查

  column name format a15

  column blocks heading "ALLOCATED|BLOCKS"

  column lf_blks heading "LEAF|BLOCKS"

  column br_blks heading "BRANCH|BLOCKS"

  column Empty heading "UNUSED|BLOCKS"

  select name,

  blocks,

  lf_blks,

  br_blks,

  blocks-(lf_blks+br_blks) empty

  from index_stats;

  或者

  select name, btree_space, used_space, pct_used from index_stats;

  回收空间方法

  'Compatible' 必须 >=10.0

  1. Enable row movement for the table.

  SQL> ALTER TABLE scott.emp ENABLE ROW MOVEMENT;

  2. Shrink table but don't want to shrink HWM (High Water Mark).

  SQL> ALTER TABLE scott.emp SHRINK SPACE COMPACT;

  3. Shrink table and HWM too.

  SQL> ALTER TABLE scott.emp SHRINK SPACE;

  4. Shrink table and all dependent index too.

  SQL> ALTER TABLE scott.emp SHRINK SPACE CASCADE;

  5. Shrink table under MView.

  SQL> ALTER TABLE

  SHRINK SPACE;

  6. Shrink Index only.

  SQL> ALTER INDEX SHRINK SPACE;

  验证

  SQL> set serveroutput on

  SQL> declare

  2 v_unformatted_blocks number;

  3 v_unformatted_bytes number;

  4 v_fs1_blocks number;

  5 v_fs1_bytes number;

  6 v_fs2_blocks number;

  7 v_fs2_bytes number;

  8 v_fs3_blocks number;

  9 v_fs3_bytes number;

  10 v_fs4_blocks number;

  11 v_fs4_bytes number;

  12 v_full_blocks number;

  13 v_full_bytes number;

  14 begin

  15 dbms_space.space_usage ('SYSTEM', 'T_SHRINK', 'TABLE', v_unformatted_blocks,

  16 v_unformatted_bytes, v_fs1_blocks, v_fs1_bytes, v_fs2_blocks, v_fs2_bytes,

  17 v_fs3_blocks, v_fs3_bytes, v_fs4_blocks, v_fs4_bytes, v_full_blocks, v_full_bytes);

  18 dbms_output.put_line('Unformatted Blocks = '||v_unformatted_blocks);

  19 dbms_output.put_line('FS1 Blocks = '||v_fs1_blocks);

  20 dbms_output.put_line('FS2 Blocks = '||v_fs2_blocks);

  21 dbms_output.put_line('FS3 Blocks = '||v_fs3_blocks);

  22 dbms_output.put_line('FS4 Blocks = '||v_fs4_blocks);

  23 dbms_output.put_line('Full Blocks = '||v_full_blocks);

  24 end;

  25 /

  Unformatted Blocks = 0

  FS1 Blocks = 0

  FS2 Blocks = 0

  FS3 Blocks = 0

  FS4 Blocks = 2

  Full Blocks = 1

时间: 2024-12-29 22:01:58

如何检查oracle表或索引可回收空间的相关文章

检查oracle表和索引可回收空间!!

不错的文章~~工作中很常用. 记录学习. 交流群127591054 原帖地址:http://www.3lian.com/edu/2013/11-29/111321.html 对表进行大量删除后,可能会有很多空闲空间可以回收,相关计算方法参考如下: 更新统计信息 Analyze table compute statistics ; 计算碎片空间 SELECT TABLE_NAME , (BLOCKS *8192 / 1024/1024 ) - (NUM_ROWS*AVG_ROW_LEN/1024/

如何彻底的删除Oracle表 及 闪回恢复在回收站里的数据

当一个表被删除时,它并不是真正的被删除了,而只是放在回收站里(recyclebin)了,当然只要表还在回收站里,它就可以被重新恢复,这也就是"闪回"技术的基本原理.需要说明的是,oracle并不提供100%的闪回,因为当用户在某个表空间里创建一个新表时或需要磁盘空间时,oracle首先使用空闲的磁盘空间,当没有足够的磁盘空间时,oracle会使用回收站的磁盘空间. 2 删除表 test 3 查看 回收站 SQL> show recyclebinORIGINAL NAME    R

如何分析oracle表或oracle索引

在CREATE INDEX和ALTER INDEX REBUILD时可以指定COMPUTE STATISTICS语句,对于非分区表重建索引时会收集表.列和索引的统计信息.对于分区表,只收集索引信息,不会收集表和列信息. 可以在将METHOD_OPT参数设置为"FOR ALL HIDDEN COLUMNS SIZE N"来收集函数索引的索引表达式信息. 1.Oracle根据下列条件来决定使用哪些索引: 索引中的记录数: 索引中不同键值的数量: 索引的层数: 索引中的叶块数: 聚集因子:

Oracle中如何把表和索引放在不同的表空间里

Oracle中并没有区分表空间里放的是表还是索引,所有当数据量比较小时,完全可以把表和索引放在同一个表空间里,但随着数据量的增大,最好还是把表和索引分开存储在不同的表空间里   因为:1)提高性能:尽量把表和索引的表空间存储在不同在磁盘上,把两类不同IO性质的数据分开放,这样可以提高磁盘的IO总体性能: 2)便于管理:试想一下,如果索引的数据文件损坏,只要创建索引即可,不会引起数据丢失的问题. 下面语句用于移动索引的表空间: 复制代码 代码如下: alter index INDEX_OWNER.

oracle表空间,角色,权限,表,索引,序列号,视图,同义词,约束条件,存储函数和过程,常用数据字典,基本数据字典信息,查看VGA信息,维护表空间,创建表空间等信息

查看当前用户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user_role_privs; 查看当前用户的系统权限和表级权限 SQL>select * from user_sys_privs;        结果可以是:        USERNAME                       PRIVILEGE                    

Oracle轻松取得建表和索引的DDL语句_oracle

我们都知道在9i之前,要想获得建表和索引的语句是一件很麻烦的事.我们可以通过export with rows=no来得到,但它的输出因为格式的问题并不能直接拿来用.而另一种方法就是写复杂的脚本来查询数据字典,但这对于一稍微复杂的对象,如IOT和嵌套表等,还是无法查到. 从数据字典中获得DDL语句是经常要用的,特别是在系统升级/重建的时候.在Oracle 9i中,我们可以直接通过执行dbms_metadata从数据字典中查处DDL语句.使用这个功能强大的工具,我们可以获得单个对象或整个SCHEMA

Oracle 9i轻松取得建表和索引的DDL语句_oracle

正在看的ORACLE教程是:Oracle 9i轻松取得建表和索引的DDL语句.我们都知道在9i之前,要想获得建表和索引的语句是一件很麻烦的事.我们通常的做法都是通过export with rows=no来得到,但它的输出因为格式的问题并不能直接拿来用.而另一种方法就是写复杂的脚本来查询数据字典,但这对于一稍微复杂的对象,如IOT和嵌套表等,还是无法查到. 从数据字典中获得DDL语句是经常要用的,特别是在系统升级/重建的时候.在Oracle 9i中,我们可以直接通过执行dbms_metadata从

Oracle中如何把表和索引放在不同的表空间里_oracle

因为:1)提高性能:尽量把表和索引的表空间存储在不同在磁盘上,把两类不同IO性质的数据分开放,这样可以提高磁盘的IO总体性能: 2)便于管理:试想一下,如果索引的数据文件损坏,只要创建索引即可,不会引起数据丢失的问题. 下面语句用于移动索引的表空间: 复制代码 代码如下: alter index INDEX_OWNER.INDEX_NAME rebuild tablespace NEW_TBS; 也可以利用以下语句获得某个schema下移动索引表空间的所有语句: 复制代码 代码如下: selec

ORACLE表空间管理维护

1:表空间概念   在ORACLE数据库中,所有数据从逻辑结构上看都是存放在表空间当中,当然表空间下还有段.区.块等逻辑结构.从物理结构上看是放在数据文件中.一个表空间可由多个数据文件组成. 如下图所示,一个数据库由对应一个或多个表空间,表空间逻辑上有一个或多个段(Segment)组成,物理上由一个或多个os file组成.       1.1基本的表空间   系统中默认创建的几个表空间:     SYSTEM     SYSAUX     USERS     UNDOTBS1     EXAM