Re: Better Delete method
Date: Sun, 11 Jul 2021 21:59:33 +0100
Message-ID: <CAGtsp8mxaUZY1ewD6HKB78OWZcKpS_DNFnKd3iyUZDOCD64Uiw_at_mail.gmail.com>
Your best strategy is to upgrade to a version that is at least 12.2, then
use the mechanism:
alter table modify
(see: https://jonathanlewis.wordpress.com/2017/06/09/12-2-partitions/)
Or if you can't work out what the partiitoning should be then 12.2 also
allows the simpler:
Any other strategy is a waste of human effort, and if you stick with
11.2.0.4 you'll probably end up repeating the task some time in the future
after you finally upgrade to a maintained version of Oracle.
You've mentioned elsewhere that you have some concernt about a multi-column
index that has a blevel (or was it height) of 4. If that's the main reason
why you want to delete lots of and rebuild the index RIGHT NOW (rather than
waiting for the upgrade) then you need to check whether you could minimise
the effort to rebuilding the index; or even just collecting the stats
differently:
Questions to ask yourself:
partitoon ...
including rows where ...
online
update indexes ...
alter table t1 move
including rows where ...
online
;
enough difference?
Regards
Jonathan Lewis
On Sat, 10 Jul 2021 at 20:47, Lok P <loknath.73_at_gmail.com> wrote:
> Hello , this database version is 11.2.0.4 of Oracle Exadata. A table(say
> TAB1) is there holding ~900 million rows with size ~222GB and it's not
> partitioned. It has two indexes , one with a three column composite index
> with size ~98Gb and other is the primary key on one column with size ~23GB.
> As a part of the requirement we need to delete/purge 50% of its data from
> this table. No referential constraints exist here. So I wanted to
> understand, out of the two below, which is the best method to opt for? or
> any other possible better option?
>
> I can understand method-1 is achievable ONLINE, but is slower while
> method-2 will be faster. So if we can afford ~1-2hrs of downtime, is it
> good to go for method -2 as the delete approach. As because deleting 50%
> rows even in method-1 may also need a table move+index rebuild(which will
> again need downtime on 11.2) to lower the high water mark and make the
> indexes compact and back to normal. Please advise.
>
>
> Method-1:-
>
> steps- 1:
> In a cursor pick the ~450million rowids of the rows to be deleted based
> on filter criteria;
> step2:-
> Delete based on ROW_IDS in a bulk collect fashion with LIMIT 50K rows
> ids at oneshot and commit within loop.
>
> Method-2:-
>
> Step- 1
> Create a new table using CTAS a new table TAB1_BKP AS select * from
> TAB1 where (required filter criteria which will pick ~450 required rows);
> Step-2:-
> Create the composite index in parallel.to make it as fast as
> possible
> Create the unique index on the same column as there in PK.
> Create the primary constraints with NOVALIDATE(because creating it
> with validate may take a lot of time to validate existing data) using the
> above unique index (This operation should happen in seconds as the index is
> already created in the above step.)
> Rename the TAB1_BKP as TAB1 and TAB1 as TAB1_BKP(which can be served as
> backup for a few days and later dropped).
>
>
>
>
-- http://www.freelists.org/webpage/oracle-lReceived on Sun Jul 11 2021 - 22:59:33 CEST