文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

回收数据库表空间的一个思路

2024-04-02 19:55

关注

  有些项目比较小,硬盘空间也只有40多G,加上无人维护,久而久之就出现了硬盘空间告警的问题。经过查看之后,发现有些数据文件一开始就设置成2G,但实际可能就只使用了100M左右。为了解决硬盘空间告警的问题,就想到了重置数据文件大小的方法。

第一步是查看各个表空间的适用率,找出可以缩小的数据文件。

--查看表空间使用率,找到闲置的表空间

SELECT Upper(F.TABLESPACE_NAME)         "表空间名",

       D.TOT_GROOTTE_MB                 "表空间大小(M)",

       D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",

       To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99')

       || '%'                           "使用比",

       F.TOTAL_BYTES                    "空闲空间(M)",

       F.MAX_BYTES                      "最大块(M)"

FROM   (SELECT TABLESPACE_NAME,

               Round(Sum(BYTES) / ( 1024 * 1024 ), 2) TOTAL_BYTES,

               Round(Max(BYTES) / ( 1024 * 1024 ), 2) MAX_BYTES

        FROM   SYS.DBA_FREE_SPACE

        GROUP  BY TABLESPACE_NAME) F,

       (SELECT DD.TABLESPACE_NAME,

               Round(Sum(DD.BYTES) / ( 1024 * 1024 ), 2) TOT_GROOTTE_MB

        FROM   SYS.DBA_DATA_FILES DD

        GROUP  BY DD.TABLESPACE_NAME) D

WHERE  D.TABLESPACE_NAME = F.TABLESPACE_NAME

ORDER  BY 4 desc;


第二步是查看所选择的表空间数据文件的高水位线,以USERS表空间为例。

-- 查找表空间的高水线

SELECT *

      FROM (SELECT

             a.file_id,

             a.file_name,

             a.filesize,

             b.freesize,

             (a.filesize - b.freesize) usedsize,

             c.hwmsize, -- 高水位线

             c.hwmsize - (a.filesize - b.freesize) unsedsize_belowhwm,

            a.filesize - c.hwmsize canshrinksize

             FROM (SELECT file_id,

                          file_name,

                          round(bytes / 1024 / 1024) filesize

                     FROM dba_data_files) a,

                  (SELECT file_id, round(SUM(dfs.bytes) / 1024 / 1024) freesize

                     FROM dba_free_space dfs

                    GROUP BY file_id) b,

                  (SELECT file_id, round(MAX(block_id) * 8 / 1024) HWMsize

                     FROM dba_extents

                    GROUP BY file_id) c

            WHERE a.file_id = b.file_id

              AND a.file_id = c.file_id

            ORDER BY unsedsize_belowhwm DESC)

    WHERE file_id IN (SELECT file_id

                        FROM dba_data_files

                       WHERE tablespace_name = 'USERS')

    ORDER BY file_id;

第三步是使用管理员账号登录,执行:

alter database datafile file_id resize N M/G;-- N 为任意整数

alter database datafile file_id autoextend on next 100M maxsize 1G;

通过以上3个步骤,就可以临时解决磁盘空间告警的问题。




阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯