Monis Iqbal
Monis Iqbal

Reputation: 2037

What are the effects of disabling the redo logs in Oracle on Hibernate transactions?

If we disable the 'redo logs' of a tablespace in Oracle, will they impact Hibernate's transactions? These are the options present in the Oracle EM on a tablespace level:

Enable logging Yes Generate redo logs for creation of tables, indexes and partitions, and for subsequent inserts. Recoverable No Redo log entries are smaller, the above operations are not logged and not recoverable.

Also, is Oracle's commit/rollback functionality dependent upon these redo logs?

Upvotes: 3

Views: 8968

Answers (2)

Vincent Malgrat
Vincent Malgrat

Reputation: 67762

Redo logs are an integrated part of the Oracle RDBMS, you can disable them in only a few special cases:

  • bulk load of data,
  • creating/recreating of indexes

If you disable the generation of redo logs for one of these operations, you will lose the ability to recover your database fully after this point (ie: you should immediately backup your database after those batch jobs are complete).

You can not disable the generation of redo for simple transactions. You wouldn't want to anyway, since they allow the database to recover after a crashed instance (online redo log, even if you are in NOARCHIVELOG) and allow media recovery after a crashed disk for example (archived redo log, only in ARCHIVELOG).

Upvotes: 7

APC
APC

Reputation: 146269

Redo logs have nothing to do with transactions. They are there for recovering your database in the event of a crash or an OS file corruption. If you don't have redo logging on, then if anything goes wrong with the database your users will lose all their work since the last good back up.

Normally we would only want to disable logging on a tablespace prior to a bulk data load. The first action after that load would be to take a backup and then re-enable logging. Not logging in a transactional system is a very bad idea.

Upvotes: 8

Related Questions