/*****************************************************************
原因:由于原导出数据库没有整理表空间其中主要包括两方面,
一是用户产生太多的DELETE,致使表的高位线(HWM)在很高的位置,
所以尽管数据量很小,但是占据的表空间很大,二是索引没有重建,
频繁的删除以及更新使得索引越来越大,REBUILD索引是个很必要的事情
*****************************************************************/

--** 优先处理CUX客制化对象

--Step1
--Tablespace Summary
  SELECT A.TABLESPACE_NAME,
         A.TOTAL M_TOTAL,
         NVL (B.USED, 0) M_USED,
         NVL ( (B.USED / A.TOTAL) * 100, 0) PCT_USED,
         A.FILE_NAME
    FROM (  SELECT TABLESPACE_NAME,
                   SUM (BYTES) / (1024 * 1024) TOTAL,
                   WMSYS.WM_CONCAT (FILE_NAME) FILE_NAME
              FROM SYS.DBA_DATA_FILES
          GROUP BY TABLESPACE_NAME) A,
         (SELECT TABLESPACE_NAME, BYTES / (1024 * 1024) USED
            FROM SYS.SM$TS_USED) B
   WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME(+)
   --AND A.TABLESPACE_NAME LIKE 'CUX%'
ORDER BY NVL ( (B.USED / A.TOTAL) * 100, 0) DESC;

--Tablespace Objects Detail
  SELECT A.TABLESPACE_NAME,
         A.TOTAL M_TOTAL,
         NVL (B.USED, 0) M_USED,
         NVL ( (B.USED / A.TOTAL) * 100, 0) PCT_USED,
         A.FILE_NAME,
         C.OJBECT_TYPE,
         C.OJBECT_NAME,
         C.M_OBJ_USED,
         NVL ( (C.M_OBJ_USED / A.TOTAL) * 100, 0) PCT_OBJ_USED
    FROM (  SELECT TABLESPACE_NAME,
                   SUM (BYTES) / (1024 * 1024) TOTAL,
                   WMSYS.WM_CONCAT (FILE_NAME) FILE_NAME
              FROM SYS.DBA_DATA_FILES
          GROUP BY TABLESPACE_NAME) A,
         (SELECT TABLESPACE_NAME, BYTES / (1024 * 1024) USED
            FROM SYS.SM$TS_USED) B,
         (SELECT TABLESPACE_NAME,
                 SEGMENT_NAME OJBECT_NAME,
                 SEGMENT_TYPE OJBECT_TYPE,
                 (BYTES / 1024 / 1024) M_OBJ_USED
            FROM DBA_SEGMENTS
           WHERE SEGMENT_TYPE IN ('TABLE', 'INDEX')) C
   WHERE     A.TABLESPACE_NAME = B.TABLESPACE_NAME(+)
         AND A.TABLESPACE_NAME = C.TABLESPACE_NAME(+)
ORDER BY NVL ( (B.USED / A.TOTAL) * 100, 0) DESC;

--Step2
-------------------------------------
--释放高水位线 HWM
--只对有清理过数据的表对象执行(耗时过长)
DECLARE
   L_SQL1        VARCHAR2 (1000);
   L_SQL2        VARCHAR2 (1000);
BEGIN
   FOR R IN (SELECT (OWNER || '.' || SEGMENT_NAME) OBJ
               FROM DBA_SEGMENTS
              WHERE SEGMENT_TYPE = 'TABLE' AND TABLESPACE_NAME LIKE 'CUX%'
              AND SEGMENT_NAME IN('CUX_INV_ISSUE_OA_LOG'))
   LOOP
      L_SQL1 := 'alter table ' || R.OBJ || ' enable row movement';
      L_SQL2 := 'alter table ' || R.OBJ || ' shrink space';
      DBMS_OUTPUT.PUT_LINE (R.OBJ);

EXECUTE IMMEDIATE L_SQL1;
      EXECUTE IMMEDIATE L_SQL2;
   END LOOP;
END;

-------------------------------
/*
--暂不应用
--Rebuild Index
DECLARE
   L_SQL   VARCHAR2 (1000);
BEGIN
   FOR R IN (SELECT (OWNER||'.'||SEGMENT_NAME) OBJ
               FROM DBA_SEGMENTS
              WHERE SEGMENT_TYPE = 'INDEX' AND TABLESPACE_NAME = 'CUX_INDEX')
   LOOP
      L_SQL := 'alter index ' || R.OBJ || ' rebuild online';
      DBMS_OUTPUT.PUT_LINE (L_SQL);

EXECUTE IMMEDIATE L_SQL;
   END LOOP;
END;
*/

--删除表同时删除回收站 Shift+Delete
--DROP TABLE CUX.CUX_INV_ISSUE_OA_LOG_TEST1 PURGE;
--alter database datafile 'filename' resize size;

Oracle释放高水位线的更多相关文章

  1. Oracle的高水位线

    一.什么是水位线 所有的oracle段都会有一个在段内容纳数据的上线,把这个上限成为“high water mark”,这是一个标记,用来说明已经有多少没有使用的数据块分配给这个段,原则上high w ...

  2. Oracle数据库入门——高水位线详解

    一.什么是水线(High Water Mark)? 所有的oracle段(segments,在此,为了理解方便,建议把segment作为表的一个同义词) 都有一个在段内容纳数据的上限,我们把这个上限称 ...

  3. oracle 高水位线详解

    一.什么是水线(High Water Mark)? 所有的oracle段(segments,在此,为了理解方便,建议把segment作为表的一个同义词) 都有一个在段内容纳数据的上限,我们把这个上限称 ...

  4. 一、oracle 高水位线详解

    一.什么是水线(High Water Mark)? 所有的oracle段(segments,在此,为了理解方便,建议把segment作为表的一个同义词) 都有一个在段内容纳数据的上限,我们把这个上限称 ...

  5. [转载]oracle 高水位线详解

    一.oracle 高水位线详解 出处: https://www.cnblogs.com/linjiqin/archive/2012/01/15/2323030.html 一.什么是水线(High Wa ...

  6. 08 Oracle表碎片查询以及整理(高水位线)

    Oracle表碎片查询以及整理(高水位线) 1.表碎片的来源 当针对一个表的删除操作很多时,表会产生大量碎片.删除操作释放的空间不会被插入操作立即重用,甚至永远也不会被重用. 2.怎样确定是否有表碎片 ...

  7. oracle 基础知识(十五)----高水位线

    一,oracle的逻辑存储管理 ORACLE的逻辑存储管理,分4个粒度:表空间,段,区和块. ## 块 粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是 ...

  8. ORACLE 11g 生产中高水位线(HWM)处理

    数据库中表不断的insert,delete,update,导致表和索引出现碎片.这会导致HWM之前有很多的空闲空间,而oracle在做全表扫描的时候会读取HWM一下的所有块,这样会产生更多的IO,影响 ...

  9. oracle 高水位线

    一.oracle 高水位线详解 一.什么是水线(High Water Mark)? 概念: 1.块: 是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是 ...

随机推荐

  1. Codeforces Round #510 #C Array Product

    http://codeforces.com/contest/1042/problem/C 给你一个有n个元素序列,有两个操作:1,选取a[i]和a[j],删除a[i],将$a[i]*a[j]$赋值给a ...

  2. modprode

    modprobe命令 1.modprobe 命令是根据depmod -a的输出/lib/modules/version/modules.dep来加载全部的所需要模块. 2.删除模块的命令是:modpr ...

  3. python--MySQL 库,表的详细操作

    一 库操作 数据库命名规则 可以由数字,字母,下划线,@, #, $ 区分大小写 唯一性 不能使用关键字如 create  select 不能单独使用数字 最长128位 # 这些是对上次的补充. 二 ...

  4. LeetCode 653. Two Sum IV – Input is a BST

    Given a Binary Search Tree and a target number, return true if there exist two elements in the BST s ...

  5. JavaScript正则表达式-重复次数(数量词)

    *:表示对前面表达式的匹配出现零次或多次. var reg_pattern = /bo*/;//匹配b.bo.boooo +:表示对前面表达式的匹配连续出现一次或多次. var reg_pattern ...

  6. Puppet 安装配置

    环境说明: OS:CentOS 5.4 i386 puppetmaster    192.168.0.12    hostname: puppetmaster.info.com client      ...

  7. 【03】github的markdown语法

    [03]github的markdown语法 https://guides.github.com/features/mastering-markdown/(下图)(魔芋:已录入)   http://ma ...

  8. x86保护模式 二 分段管理机制

    分段管理机制 段选择子和偏移地址的二维虚拟地址转换为一维的线性地址 一  段定义和虚拟地址到线性地址的转换 三个参数定义段:段基地址    段界限  和段属性    同时也是段描述符的结构 段基地址为 ...

  9. [automator学习篇]android 接口-- bluetooth

    http://www.android-doc.com/guide/topics/connectivity/bluetooth.html 本地下载的sdk 目录:     D:\AndroidSdk\s ...

  10. 【Luogu】P3402最长公共子序列(LCS->nlognLIS)

    题目链接 SovietPower 的题解讲的很清楚.Map或Hash映射后用nlogn求出LIS.这里只给出代码. #include<cstdio> #include<cctype& ...