ORACLE 数据块空间使用查询

编写以下过程查询数据块使用空间

create or replace procedure space_of_use(v_segment_owner in varchar2 default user,v_segment_name in varchar2,v_segment_type varchar2 default 'TABLE',v_partition_name in varchar2 default null)
as
  --空閒介於0%-25%之間的數據塊
  fs1_blocks number;
  fs1_bytes number;
  --空閒介於25%-50%之間的數據塊
  fs2_blocks number;
  fs2_bytes number;
  --空閒介於50%-75%之間的數據塊
  fs3_blocks number;
  fs3_bytes number;
  --空閒介於75%-100%之間的數據塊
  fs4_blocks number;
  fs4_bytes number;
  --全部填滿的數據塊
  full_blocks number;
  full_bytes number;
  --未格式化的數據塊
  noformatted_blocks number;
  noformatted_bytes number;
  begin
    dbms_space.space_usage(
    segment_owner => v_segment_owner,
    segment_name => v_segment_name,
    segment_type => v_segment_type,
    fs1_bytes => fs1_bytes,
    fs1_blocks => fs1_blocks,
    fs2_bytes => fs2_bytes,
    fs2_blocks=>fs2_blocks,
    fs3_bytes => fs3_bytes,
    fs3_blocks => fs3_blocks,
    fs4_bytes => fs4_bytes,
    fs4_blocks => fs4_blocks,
    full_bytes => full_bytes,
    full_blocks => full_blocks,
    unformatted_blocks => noformatted_blocks,
    unformatted_bytes => noformatted_bytes,
    partition_name => v_partition_name
    );
    dbms_output.put_line('未格式化的數據塊'||noformatted_blocks);
    dbms_output.put_line('空閒介於0%-25%之間的數據塊'||fs1_blocks);
    dbms_output.put_line('空閒介於25%-50%之間的數據塊'||fs2_blocks);
    dbms_output.put_line('空閒介於50%-75%之間的數據塊'||fs3_blocks);
    dbms_output.put_line('空閒介於75%-100%之間的數據塊'||fs4_blocks);
    dbms_output.put_line('全部填滿的數據塊'||full_blocks);
  end;

—普通表
begin
space_of_use(‘SEGMENT_OWNER’,‘SEGMENT_NAME’,‘TABLE’);
end;

–分區表
begin
space_of_use(‘SEGMENT_OWNER’,‘SEGMENT_NAME’,‘TABLE PARTITION’,‘PARTITION_NAME’);
end;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值