Oracle FAQ | Your Portal to the Oracle Knowledge Grid |
![]() |
![]() |
Home -> Community -> Mailing Lists -> Oracle-L -> RE: How to project the time a delete will take
Dear Nelson,
Oracle release 8.1.7.4, solaris 8=20
The entries that will be deleted are ~ 200 million . The customer is
pushing for delete although we have pointed out that a partition will be
wiser (we are using truncate now). The customer asked us to prove that
the delete is not efficient although we have explained that there are a
number of issues such as redo and undo etc. There are 3 indexes defined
against the table.
I am doing the following experiment
a) get a reading from dbms_utility.get_time b) execute a delete for a row c) get a second reading from dbms_utility.get_time d) Check the diff between a and c which is 732 centiceconds (if Iconvert it well is 7,32 secs)
Kind Regards,
Hatzistavrou Yannis
-----Original Message-----
From: nelson.petersen_at_homehardware.ca
[mailto:nelson.petersen_at_homehardware.ca]=20
Sent: Friday, January 30, 2004 4:25 PM
To: oracle-l_at_freelists.org
Subject: RE: How to project the time a delete will take
Hi John (Yannis?),
Assumptions:
I don't have a way for you to estimate how long the delete will take. I have a suggestion, though.
What version of Oracle are you running?
If you're on Oracle 8.1.5 or higher (I think EXPORT has the QUERY option
as
of 8.1.5)
you might consider the following:
EXPORT ... QUERY=3D"WHERE ..." file=3Ddata_to_be_left.dmp etc. >>> The WHERE clause should select the data that you do *NOT* want to delete.
Truncate the table.
IMPORT file=3Ddata_to_be_left.dmp ... etc.
This is a quick way to delete large amounts of data. REDO generated by IMPORT might be less than that generated by DELETE.
As always, test on a test database before trusting this in production!
If you are on earlier versions of Oracle, there are ways to do something
similar
using CREATE TABLE AS SELECT * FROM table1 WHERE
data_col=3D'data_you_need_to_keep';
Of course, it all depends on how much data you need to save. You don't say if this table has 101 million rows or 10,000 million rows.
HTH,
Nelson Petersen
Database Administrator
Home Hardware Stores Limited.
Nelson.Petersen_at_homehardware.ca
-----Original Message-----
From: Hatzistavrou John [mailto:John.Hatzistavrou.sema_at_mail.tellas.gr]
Sent: Friday, January 30, 2004 7:48 AM
To: oracle-l_at_freelists.org
Subject: How to project the time a delete will take
Dear All,
=20
Is there a formula that can give an estimation on how long a delete operation will take on a tables to delete 100 million rows?
=20
Kind Regards,
=20
=20
Hatzistavrou Yannis
=20
FAQ is at http://www.freelists.org/help/fom-serve/cache/1.htmlput 'unsubscribe' in the subject line.
-----------------------------------------------------------------
----------------------------------------------------------------
Please see the official ORACLE-L FAQ: http://www.orafaq.com
----------------------------------------------------------------
To unsubscribe send email to: oracle-l-request_at_freelists.org
FAQ is at http://www.freelists.org/help/fom-serve/cache/1.htmlput 'unsubscribe' in the subject line.
-----------------------------------------------------------------
----------------------------------------------------------------
Please see the official ORACLE-L FAQ: http://www.orafaq.com
----------------------------------------------------------------
To unsubscribe send email to: oracle-l-request_at_freelists.org
![]() |
![]() |