When deleting from a large table in Oracle – let’s call it table X – does it make sense to disable table X’s FKs that do not have ON DELETE CASCADE? I’m not referring to disabling FKs on other tables that link to table X, but just disabling FKs on table X to improve the performance of the DELETE statements.
I’m making the indexes on table X unusable, but the DELETE still takes a while.
I think that those FKs don’t matter to the performance of the DELETE statement since we’re just deleting, and not inserting or updating, so the FKs don’t need to be checked. What do you think?
Eventually I didn’t have to disable those FKs before the archive process starts and enable them when the process ends. But instead, in order to improve performance of the DELETE statements, we had to drop indexes before the archive process starts and recreate them after the archive process finishes. We also committed more often.