<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業(yè)精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 ::  :: 管理 ::
      397 隨筆 :: 33 文章 :: 29 評論 :: 0 Trackbacks
    show_space
    ?
    ??? Tom的show_space備份一下。非常有用!!!
    ?
    ?
    CREATE OR REPLACE PROCEDURE show_space(p_segname IN VARCHAR2,
    ?????????????????????????????????????? p_owner IN VARCHAR2 DEFAULT 'USER',
    ?????????????????????????????????????? p_type IN VARCHAR2 DEFAULT 'TABLE',
    ?????????????????????????????????????? p_partition IN VARCHAR2 DEFAULT NULL
    ?????????????????????????????????????? )
    AUTHID CURRENT_USER
    AS
    ? l_free_blks ??? NUMBER;
    ? l_total_blocks NUMBER;
    ? l_total_bytes ? NUMBER;
    ? l_unused_blocks NUMBER;
    ? l_unused_bytes NUMBER;
    ? l_lastusedextfileid NUMBER;
    ? l_lastusedextblockid NUMBER;
    ? l_last_used_block ?? NUMBER;
    ? PROCEDURE p (p_label IN VARCHAR2, p_num IN NUMBER)
    ? IS
    ? BEGIN
    ??? DBMS_OUTPUT.put_line (RPAD (p_label, 40, '.') || p_num);
    ? END;

    BEGIN
    ? FOR x IN (SELECT tablespace_name
    ????????????? FROM user_tablespaces
    ???????????? WHERE tablespace_name =
    ?????????????????? (SELECT tablespace_name
    ????????????????????? FROM user_segments
    ???????????????????? WHERE segment_type = p_type
    ?????????????????????? AND segment_name = p_segname
    ?????????????????????? AND segment_space_management <> 'AUTO'))
    ? LOOP
    ??? DBMS_SPACE.free_blocks (segment_owner => p_owner,
    ??????????????????????????? segment_name => p_segname,
    ??????????????????????????? segment_type => p_type,
    ??????????????????????????? partition_name => p_partition,
    ??????????????????????????? freelist_group_id => 0,
    ??????????????????????????? free_blks => l_free_blks
    ??????????????????????????? );
    ? END LOOP;
    ? DBMS_SPACE.unused_space (segment_owner => p_owner,
    ?????????????????????????? segment_name => p_segname,
    ?????????????????????????? segment_type => p_type,
    ?????????????????????????? partition_name => p_partition,
    ?????????????????????????? total_blocks => l_total_blocks,
    ?????????????????????????? total_bytes => l_total_bytes,
    ?????????????????????????? unused_blocks => l_unused_blocks,
    ?????????????????????????? unused_bytes => l_unused_bytes,
    ?????????????????????????? last_used_extent_file_id => l_lastusedextfileid,
    ?????????????????????????? last_used_extent_block_id => l_lastusedextblockid,
    ?????????????????????????? last_used_block => l_last_used_block
    ?????????????????????????? );
    ? p ('Free Blocks', l_free_blks);
    ? p ('Total Blocks', l_total_blocks);
    ? p ('Total Bytes', l_total_bytes);
    ? p ('Total MBytes', TRUNC (l_total_bytes / 1024 / 1024));
    ? p ('Unused Blocks', l_unused_blocks);
    ? p ('Unused Bytes', l_unused_bytes);
    ? p ('Last Used Ext FileId', l_lastusedextfileid);
    ? p ('Last Used Ext BlockId', l_lastusedextblockid);
    ? p ('Last Used Block', l_last_used_block);
    END;
    /
    ?

    ??? 修改后支持 ASSM 的 show_space script
    ?
    ?
    create or replaceprocedure show_space(p_segname_1 in varchar2,
    ??????????????????????????????????????? p_space in varchar2 default 'MANUAL',
    ??????????????????????????????????????? p_type_1 in varchar2 default 'TABLE' ,
    ??????????????????????????????????????? p_freespace in varchar2 default 'N',
    ??????????????????????????????????????? p_owner_1 in varchar2 default user)
    as
    ? p_segname varchar2(100);
    ? p_type ?? varchar2(10);
    ? p_owner ? varchar2(30);
    ?
    ? l_unformatted_blocks number;
    ? l_unformatted_bytes number;
    ? l_fs1_blocks number;
    ? l_fs1_bytes number;
    ? l_fs2_blocks number;
    ? l_fs2_bytes number;
    ? l_fs3_blocks number;
    ? l_fs3_bytes number;
    ? l_fs4_blocks number;
    ? l_fs4_bytes number;
    ? l_full_blocks number;
    ? l_full_bytes number;
    ?
    ? l_free_blks number;
    ? l_total_blocks number;
    ? l_total_bytes number;
    ? l_unused_blocks number;
    ? l_unused_bytes number;
    ? l_LastUsedExtFileId number;
    ? l_LastUsedExtBlockId number;
    ? l_LAST_USED_BLOCK number;
    ?
    ? procedure p( p_label in varchar2, p_num in number )
    ? is
    ? begin
    ??? dbms_output.put_line( rpad(p_label,40,'.') ||p_num );
    ? end;
    begin
    ? p_segname := upper(p_segname_1); -- rainy changed?
    ? p_owner := upper(p_owner_1);
    ? p_type := p_type_1;
    ?
    ? if (p_type_1 = 'i' or p_type_1 = 'I') then --rainy changed
    ??? p_type := 'INDEX';
    ? end if;
    ?
    ? if (p_type_1 = 't' or p_type_1 = 'T') then --rainy changed
    ??? p_type := 'TABLE';
    ? end if;
    ?
    ? if (p_type_1 = 'c' or p_type_1 = 'C') then --rainy changed
    ??? p_type := 'CLUSTER';
    ? end if;

    ? dbms_space.unused_space(segment_owner => p_owner,
    ?????????????????????????? segment_name => p_segname,
    ?????????????????????????? segment_type => p_type,
    ?????????????????????????? total_blocks => l_total_blocks,
    ?????????????????????????? total_bytes => l_total_bytes,
    ?????????????????????????? unused_blocks => l_unused_blocks,
    ?????????????????????????? unused_bytes => l_unused_bytes,
    ?????????????????????????? LAST_USED_EXTENT_FILE_ID => l_LastUsedExtFileId,
    ?????????????????????????? LAST_USED_EXTENT_BLOCK_ID => l_LastUsedExtBlockId,
    ?????????????????????????? LAST_USED_BLOCK => l_LAST_USED_BLOCK );
    ?
    ? if p_space = 'MANUAL' or (p_space <> 'auto' and p_space <> 'AUTO') then
    ??? dbms_space.free_blocks(segment_owner => p_owner,
    ??????????????????????????? segment_name => p_segname,
    ??????????????????????????? segment_type => p_type,
    ??????????????????????????? freelist_group_id => 0,
    ??????????????????????????? free_blks => l_free_blks );
    ?
    ??? p( 'Free Blocks', l_free_blks );
    ? end if;

    ? p( 'Total Blocks', l_total_blocks );
    ? p( 'Total Bytes', l_total_bytes );
    ? p( 'Unused Blocks', l_unused_blocks );
    ? p( 'Unused Bytes', l_unused_bytes );
    ? p( 'Last Used Ext FileId', l_LastUsedExtFileId );
    ? p( 'Last Used Ext BlockId', l_LastUsedExtBlockId );
    ? p( 'Last Used Block', l_LAST_USED_BLOCK );
    ?
    ? if p_freespace = 'Y' then
    ??? dbms_space.space_usage(segment_owner => p_owner ,
    ??????????????????????????? segment_name => p_segname ,
    ??????????????????????????? segment_type => p_type ,
    ??????????????????????????? unformatted_blocks => l_unformatted_blocks ,
    ??????????????????????????? unformatted_bytes => l_unformatted_bytes,
    ??????????????????????????? fs1_blocks => l_fs1_blocks,
    ??????????????????????????? fs1_bytes => l_fs1_bytes ,
    ??????????????????????????? fs2_blocks => l_fs2_blocks,
    ??????????????????????????? fs2_bytes => l_fs2_bytes,
    ??????????????????????????? fs3_blocks => l_fs3_blocks ,
    ??????????????????????????? fs3_bytes => l_fs3_bytes,
    ??????????????????????????? fs4_blocks => l_fs4_blocks,
    ??????????????????????????? fs4_bytes => l_fs4_bytes,
    ??????????????????????????? full_blocks => l_full_blocks,
    ??????????????????????????? full_bytes => l_full_bytes);
    ??? dbms_output.put_line(rpad(' ',50,'*'));
    ??? p( '0% -- 25% free space blocks', l_fs1_blocks);
    ??? p( '0% -- 25% free space bytes', l_fs1_bytes);
    ??? p( '25% -- 50% free space blocks', l_fs2_blocks);
    ??? p( '25% -- 50% free space bytes', l_fs2_bytes);
    ??? p( '50% -- 75% free space blocks', l_fs3_blocks);
    ??? p( '50% -- 75% free space bytes', l_fs3_bytes);
    ??? p( '75% -- 100% free space blocks', l_fs4_blocks);
    ??? p( '75% -- 100% free space bytes', l_fs4_bytes);
    ??? p( 'Unused Blocks', l_unformatted_blocks );
    ??? p( 'Unused Bytes', l_unformatted_bytes );
    ??? p( 'Total Blocks', l_full_blocks);
    ??? p( 'Total bytes', l_full_bytes);
    ?
    ? end if;
    ?
    end;
    /
    ?
    ?

    ASSM 類型的表:
    ?
    SQL> exec show_space('t','auto');
    Total Blocks............................512
    Total Bytes.............................4194304
    Unused Blocks...........................78
    Unused Bytes............................638976
    Last Used Ext FileId....................9
    Last Used Ext BlockId...................25608
    Last Used Block.........................50
    ?
    PL/SQL procedure successfully completed.
    ?
    ?

    ASSM 類型的索引:

    SQL> exec show_space('t_index','auto','i');
    Total Blocks............................80
    Total Bytes.............................655360
    Unused Blocks...........................5
    Unused Bytes............................40960
    Last Used Ext FileId....................9
    Last Used Ext BlockId...................25312
    Last Used Block.........................3
    ?
    PL/SQL procedure successfully completed.
    ?
    ?
    ?
    SQL> exec show_space('t','auto','T','Y');
    Total Blocks............................512
    Total Bytes.............................4194304
    Unused Blocks...........................78
    Unused Bytes............................638976
    Last Used Ext FileId....................9
    Last Used Ext BlockId...................25608
    Last Used Block.........................50
    *************************************************
    0% -- 25% free space blocks.............0
    0% -- 25% free space bytes..............0
    25% -- 50% free space blocks............0
    25% -- 50% free space bytes.............0
    50% -- 75% free space blocks............0
    50% -- 75% free space bytes.............0
    75% -- 100% free space blocks...........0
    75% -- 100% free space bytes............0
    Unused Blocks...........................0
    Unused Bytes............................0
    Total Blocks............................418
    Total bytes.............................3424256
    ?
    PL/SQL procedure successfully completed.
    ?

    ?
    posted on 2009-07-11 21:18 decode360 閱讀(296) 評論(0)  編輯  收藏 所屬分類: 10.DB_Tools
    主站蜘蛛池模板: 在线a亚洲老鸭窝天堂av高清| 久久笫一福利免费导航| 精品无码专区亚洲| 亚洲综合图片小说区热久久| 亚洲国产精品专区在线观看| 无码高潮少妇毛多水多水免费| 免费黄网站在线看| 三级黄色在线免费观看| 亚洲s码欧洲m码吹潮| 亚洲日本国产综合高清| 亚洲网址在线观看你懂的| 亚洲熟妇丰满多毛XXXX| mm1313亚洲精品国产| 国产精品免费视频一区| 德国女人一级毛片免费| 成年人网站在线免费观看| 青草草色A免费观看在线| 国产h肉在线视频免费观看| 最好看最新的中文字幕免费| 久久国产精品免费专区| 国产精品内射视频免费| rh男男车车的车车免费网站| 粉色视频免费入口| j8又粗又长又硬又爽免费视频| 一区二区3区免费视频| 二个人看的www免费视频| 精品国产麻豆免费人成网站| 三年片在线观看免费大全电影| 日韩精品人妻系列无码专区免费| 18成禁人视频免费网站| 免费人成网站在线观看10分钟| 成人午夜视频免费| 九月婷婷亚洲综合在线| 亚洲精品无码不卡在线播HE| 色婷婷亚洲十月十月色天| 亚洲日韩中文字幕| 黄页网站在线免费观看| 野花香高清在线观看视频播放免费| 91精品手机国产免费| 成**人免费一级毛片| 国产成人精品亚洲精品|