在使用 YashanDB 的过程中,随着数据的不断写入与删除,表空间可能会存在“看起来用掉很多,其实有大块空间可以回收”的情况。这时候我们就可以通过回收表空间的方式,释放磁盘资源,提高使用效率。
下面是回收表空间的完整操作流程,一步步来。
第一步:确认是否真的有空间可以回收
首先,我们需要查看当前表空间的高水位线情况。执行以下 SQL:
select a.tablespace_name, a.high_water_mark, b.user_bytes, b.total_bytes
from (
select tablespace_name, max(header_block + blocks) * 8192 as high_water_mark
from dba_segments
where tablespace_name = 'USERS'
group by tablespace_name
) a, dba_tablespaces b
where a.tablespace_name = b.tablespace_name;
这个查询会告诉你两个核心信息:
当前表空间的高水位线位置;
实际占用的 user bytes 和总空间。
如果 total_bytes 的值明显大于 high_water_mark,就说明存在可回收的空间,差值部分就是潜在的回收量,单位是 byte。
第二步:确认回收前的磁盘文件大小
在执行回收操作前,你也可以用系统命令看一下当前数据库文件实际占用的大小,例如:
ls -l $YASDB_DATA/dbfiles
这样可以直观看到回收前后有没有效果。
第三步:执行空间回收操作
执行如下 SQL 进行表空间收缩:
ALTER TABLESPACE USERS SHRINK SPACE KEEP 200M;
这里的 200M 参数表示“保留至少 200M 空间”,这个值必须大于高水位线所占用的空间,否则回收操作会失败。
第四步:确认回收是否成功
再次执行前面的 SQL 查询,检查 high_water_mark 是否下降,user_bytes 是否减小,或者直接用 ls 命令观察物理文件大小变化:
select a.tablespace_name, a.high_water_mark, b.user_bytes, b.total_bytes ...
ls -l $YASDB_DATA/dbfiles
如果数值有所减少,就说明回收成功了。
小结
整个过程其实就四步:
1.先确认是否有回收空间;
2.然后确认磁盘文件现状;
3.再执行 SHRINK SPACE 进行回收;
4.最后验证结果。
只要你的 KEEP 值设得合理,回收效果就会非常明显。定期清理、合理规划表空间,有助于让数据库始终保持高效运行。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。