千家信息网

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

发表于:2024-11-24 作者:千家信息网编辑
千家信息网最后更新 2024年11月24日,有些项目比较小,硬盘空间也只有40多G,加上无人维护,久而久之就出现了硬盘空间告警的问题。经过查看之后,发现有些数据文件一开始就设置成2G,但实际可能就只使用了100M左右。为了解决硬盘空间告警的问题
千家信息网最后更新 2024年11月24日回收数据库表空间的一个思路

有些项目比较小,硬盘空间也只有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 /*+ ordered use_hash(a,b,c) */

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个步骤,就可以临时解决磁盘空间告警的问题。




0