Deferred update
- Do not physically update the database on disk until after a transaction reaches its commit point;
- Then updates are recorded persistently in the log and the written to the database.
- Before reaching commit point, the transaction updates are recorded in the local transaction workspace (buffers)
- During commit, the updates are first recorded persistently in log and then write to the database.
Transaction fail
o If transaction fails before reaching commit point, it will not have changed the database. (no need undo)
o It may necessary to REDO the effect of the operations of a committed transaction from the log, because their effect may not yet have been recorded.
- Deferred update is known as “NO-UNDO/REDO Algorithm”
Recovery based on deferred update
This technique postpone any actual update to the database until the transaction complete and reached check point.
During transaction execute
o Updates are recorded in log file and in cache buffer.
o After transaction reaches it commit point and the log file is forced to write to disk, the update are record to database.
Fail before commit,
no need undo.
Simplify recovery,
- Can not use in practice because unless transaction are short and each transaction change few times.
- May running out of buffer space because transaction change must be held in buffer until commit.
- A transaction can not change the database on disk until it reaches it commit point.
- A transaction does not reach its commit point until all its update operations are recorded in the log and the log is force written to disk.
Example of Deferred Update
Example
Example :
0 comments:
Post a Comment