• Oracle数据文件收缩最新脚本


    set linesize 1000 pagesize 0 feedback off trimspool on
    with
    hwm as (
      -- get highest block id from each datafiles ( from x$ktfbue as we don't need all joins from dba_extents )
      select /*+ materialize */ ktfbuesegtsn ts#,ktfbuefno relative_fno,max(ktfbuebno+ktfbueblks-1) hwm_blocks
      from sys.x$ktfbue group by ktfbuefno,ktfbuesegtsn
    ),
    hwmts as (
      -- join ts# with tablespace_name
      select name tablespace_name,relative_fno,hwm_blocks
      from hwm join v$tablespace using(ts#)
    ),
    hwmdf as (
      -- join with datafiles, put 5M minimum for datafiles with no extents
      select file_name,nvl(hwm_blocks*(bytes/blocks),5*1024*1024) hwm_bytes,bytes,autoextensible,maxbytes
      from hwmts right join dba_data_files using(tablespace_name,relative_fno)
    )
    select
    case when autoextensible='YES' and maxbytes>=bytes
    then -- we generate resize statements only if autoextensible can grow back to current size
      '/* reclaim '||to_char(ceil((bytes-hwm_bytes)/1024/1024),999999)
       ||'M from '||to_char(ceil(bytes/1024/1024),999999)||'M */ '
       ||'alter database datafile '''||file_name||''' resize '||ceil(hwm_bytes/1024/1024)||'M;'
    else -- generate only a comment when autoextensible is off
      '/* reclaim '||to_char(ceil((bytes-hwm_bytes)/1024/1024),999999)
       ||'M from '||to_char(ceil(bytes/1024/1024),999999)
       ||'M after setting autoextensible maxsize higher than current size for file '
       || file_name||' */'
    end SQL
    from hwmdf
    where
    bytes-hwm_bytes>1024*1024 -- resize only if at least 1MB can be reclaimed
    order by bytes-hwm_bytes desc
    /
  • 相关阅读:
    PHP实现大文件下载
    使用CSS样式的三种方式
    PHP工厂模式
    使用 curl 命令发送请求
    vim 基本操作
    MAC OS 各个文件夹详细介绍以及 node 安装位置
    linux find 命令
    Mac 关闭某端口程序
    glob 模式的 Linux Shell 通配符介绍
    Mac tree 输出文件树形式
  • 原文地址:https://www.cnblogs.com/hanglinux/p/15181444.html
Copyright © 2020-2023  润新知