How to speed up deleting rows, when there are child tables?

Hi,

I want to delete nearly 9000 rows from a table of 4 million rows.

The table is having two child tables.
The table is having primary key.
primary key is used when deleting.

I tried the following, but still it is taking 3 hours
Forall statement.
Nologging.
Delete using ROWID.

Please let me know is there any other  general approach, I can try.

If you want I want, I can post more details tomorrow.
sakthikumarAsked:
Who is Participating?
 
johnsoneConnect With a Mentor Senior Oracle DBACommented:
Disable which constraints?  The foreign key constraints?  If so, were they cascade delete constraints?  If they are not cascading constraints, then I would venture a guess that the key field of the parent table is not indexed in the child table.  That would cause a significant slow down in deletes.
0
 
sdstuberCommented:
How many total rows are you deleting?  parent + child?

Based on 9000/4000000,  that's should be quick.
Less than a minute even with full table scans.

Any triggers firing?

And the most likely cause - any blocking locks from other sessions on the parent or any of the children?
0
 
johnsoneSenior Oracle DBACommented:
I assume you have cascading constraints.  If that is the case, don't use the constraints to do the deletes of the child tables.  Delete them yourself.  Locking down the parent child tree and then deleting back up the tree takes a lot of time.  We have found that deleting children first, then parents is much faster.
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
flow01Commented:
Does the child table have an index on the foreign_key columns referring to the parent table ?
0
 
Franck PachotCommented:
Hi,

The forall approach is ok if you want to do it online. You can do intermediate commits and run it ad several times for few rows. And as you can do it online, the duration should not matter.

Note that NOLOGGING has no meaning here for the delete statement.

Regards,
Franck.
0
 
sakthikumarAuthor Commented:
If I disable the constraints, it is very fast. let me check the other things.
0
 
DavidSenior Oracle Database AdministratorCommented:
Please post the entire SQL statement, changing names as necessary.
0
 
sakthikumarAuthor Commented:
Correct. It was not indexed, When it is indexed, it is fast.

Thank you very much.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.