【TUNE_ORACLE】ROWID切片SQL參考

Attack_on_Jager發表於2021-07-28

實驗環境

搭建平臺:VMware Workstation

OS:RHEL 6.10

Grid&DB:Oracle 11.2.0.4


SQL參考

create user test identified by test default tablespace users;

--先給測試使用者賦權

grant dba to test;

create table tab as select * from stu.students;  --任意copy一張表用來測試


create or replace procedure p_rowid(range number, id number) is

  cursor cur_rowid is

  -----------------------------------SQL主體-----------------------------------  

    select dbms_rowid.rowid_create(1,

                                   b.data_object_id,

                                   a.relative_fno,

                                   a.block_id,

                                   0) rowid1,

           dbms_rowid.rowid_create(1,

                                   b.data_object_id,

                                   a.relative_fno,

                                   a.block_id + blocks - 1,

                                   999) rowid2

      from dba_extents a, dba_objects b

     where a.segment_name = b.object_name

       and a.owner = b.owner

        and b.object_name = 'TAB' --表名

       and b.owner = 'TEST' --使用者名稱

       and mod(a.extent_id, range) = id;

  -----------------------------------SQL主體-----------------------------------     

  v_sql varchar2(4000);

begin

  for cur in cur_rowid loop

    v_sql := 'delete tab where student_id > 200 and rowid between :1 and :2';  --可以根據自己的SQL修改此處

    execute immediate v_sql

      using cur.rowid1, cur.rowid2;

    commit;

  end loop;

end;

/


--如果要將表切分成8份,可以在8個視窗中一次執行:

begin 

p_rowid(8,0);

end;

/

begin 

p_rowid(8,1);

end;

/

......

begin 

p_rowid(8,7);

end;

/


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69992972/viewspace-2783837/,如需轉載,請註明出處,否則將追究法律責任。

相關文章