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.
data:image/s3,"s3://crabby-images/d5072/d507241d93171a12a193a6f7a70715a06326721a" alt=""
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
data:image/s3,"s3://crabby-images/0ead7/0ead7db18d4c63d4a835273cd7ab70f7a1fcb18c" alt=""
Example
data:image/s3,"s3://crabby-images/a6056/a6056df5df7c456eaccc52ee7247f7cd39aba14e" alt=""
Example :
data:image/s3,"s3://crabby-images/467b8/467b8fc9915612de6509cec96f7b8eea76ab22c1" alt=""
0 comments:
Post a Comment