/*****************************************************************
原因:由于原导出数据库没有整理表空间其中主要包括两方面,
一是用户产生太多的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;

最新文章

  1. VUE---Missing space before function parentheses
  2. Topology and Geometry in OpenCascade-Edge
  3. 跟着官网的例子学Reacjs (一)FilterableProductTable
  4. mysql5.6中 order by 多个字段排序问题
  5. Python 程序如何高效地调试?
  6. 【背景建模】VIBE
  7. ORACLE 常用SQL查询
  8. showMonth
  9. Eclipse Maven插件无法搜索远程库
  10. 华为Java笔试题
  11. Eclipse用法和技巧五:生成说明文档2
  12. 分布式MySQL数据库TDSQL架构分析
  13. ckeditor 基础
  14. JAVA的高并发编程
  15. Invalid bound statement (not found)解决方法
  16. 云计算OpenStack:云计算介绍及组件安装(一)--技术流ken
  17. bottle.py中的路由搜索优化
  18. permutohedral lattice理解
  19. async/await 与 generator、co 的对比
  20. Lucene的查询语法,JavaCC及QueryParser(1)

热门文章

  1. 【贪心】「poj1328」Radar Installation
  2. perl学习之:编译、执行与内存关系(转)
  3. 【git】不检查特定文件的更改情况
  4. Python文件指针与Python函数
  5. 记我的小网站发现的Bug之一 —— 某用户签到了两次
  6. python基础学习笔记——开发规范
  7. python算法-插入排序
  8. 【LeetCode】Reverse Nodes in k-Group(k个一组翻转链表)
  9. oracle用户密码错误导致用户锁定
  10. 【Luogu】P1462通往奥格瑞玛的道路(二分答案+SPFA)