140 likes | 162 Vues
Explore the syntax and semantics of database transactions for ensuring consistency through formal steps and interpretations. Learn about read/write models, procedural interactions, and transaction sets.
E N D
Chapter 2 Model for transactions
Basic operations must be guaranteed to be formal consistent, atomic and isolated. Transaction 1 Transaction 2 ... Transaction n Database Read/write model We abstract from transaction semantics except for database reads and writes. Basic operations in the model? Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager We are only concerned with database consistency we are only interested in database reads and writes.
Read/write model “Syntax”: Definition 2.1 (Read/WriteModel Transaction): A transaction t is a partial order of steps (actions) of the form r(x) or w(x), where x D (D database) and reads and writes applied to the same object are strictly ordered. We write t = (op, <) for transaction t with step set op and partial order <. Examples: t1 = r(s)w(s)r(v)w(v) for short: r(s) w(s) r(v) w(v) t2 = r(s)w(s) r(v)w(v)
Read/write model “Syntax”: Definition 2.1 (Read/WriteModel Transaction): A transaction t is a partial order of steps (actions) of the form r(x) or w(x), where x D (D database) and reads and writes applied to the same object are strictly ordered. We write t = (op, <) for transaction t with step set op and partial order <. “Semantics”: Interpretation of jth step, pj, of t: If pj=r(x), then interpretation is assignment vj := x to local variable vj If pj=w(x) then interpretation is assignment x := fj (vj1, ..., vjk). with unknown function fj and j1, ..., jk denoting t‘s prior read steps. Worst-case assumption!
Read/write model Examples: t1 = r(s)w(s)r(v)w(v) for short: r(s) w(s) r(v) w(v) t2 = r(s)w(s) r(v)w(v) “Semantics”: Interpretation of jth step, pj, of t: If pj=r(x), then interpretation is assignment vj := x to local variable vj If pj=w(x) then interpretation is assignment x := fj (vj1, ..., vjk). with unknown function fj and j1, ..., jk denoting pj‘s prior read steps.
Transaction 1 Transaction 2 ... Transaction n Database Page model reads and writes on database pages. Basic data elements in the model? Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager reads and writes on database pages. Organized in data pages.
Transaction 1 Transaction 2 ... Transaction n Database Procedural model reads and writes on database pages. Transactions in the model? Procedural combination Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager reads and writes on database pages.
Procedural model “Syntax”: Definition 2.1 (Read/WriteModel Transaction): A transaction t is a partial order of steps (actions) of the form r(x) or w(x), where x D (D database) and reads and writes applied to the same object are strictly ordered. We write t = (op, <) for transaction t with step set op and partial order <. Examples: r(s)w(s) r(v)w(v) • For some operations their mutual order of execution does not affect the end result. • Definition covers the multiprocessor/parallel case.
Procedural model A transaction brackets a number of operations • read • write by • begin transaction and • end transaction or • abort r w abbrev. abbrev. b c a Successful completion of the transaction. Results are made persistent (commit). Unsuccessful termination of the transaction. Results are discarded.
Transaction model Definition 2.2 (Read/WriteModel Transaction): Atransaction tiis a partial order (opi,<i),with opi all operations in tiand 1. opi{ri(x),wi(x) | x is data element } {ai,ci } (op’i = opi\ {ai,ci }) 2.p opi p = ci p = ai (q op’i q <i p) 3. ri(x),wi(x) opi (ri(x) <i wi(x) wi(x) <i ri(x)) 4. ai opi ci opiand ci opi ai opi Each operation occurs at most once If a or c in ti, then as the last operation Reads and writes on the same element are ordered If a or c in ti, only one of them
Transaction model Definition 2.2 (Read/WriteModel Transaction): Atransaction tiis a partial order (opi,<i),with opi all operations in tiand 1. opi{ri(x),wi(x) | x is data element } {ai,ci } (op’i = opi\ {ai,ci }) 2.p opi p = ci p = ai (q op’i q <i p) 3. ri(x),wi(x) op’i (ri(x) <i wi(x) wi(x) <i ri(x)) 4. ai opi ci opiand ci opi ai opi Often excluded due to standard implementation: No read of an element after it was updated.
Transaction 1 Transaction 2 ... Transaction n Database Transaction set model reads and writes on database pages. Transaction sets in the model? Procedural combination Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager reads and writes on database pages.
Transaction 1 Transaction 2 ... Transaction n Database Transaction set model reads and writes on database pages. Notation: T={t1, ..., tn} is the set of transactions covered by a schedule. Procedural combination Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager Result of „mixing“ the of different transactions? • Result: Schedule. • Not every syntactically correct schedule is semantically correct (i.e., preserves the ACID properties). • Formal description of correct schedules needed. reads and writes on database pages.
Transaction 1 Transaction 2 ... Transaction n Database Transaction set model Algorithms for the runtime generation of semantically correct schedules? Scheduler restart restore Backup/Recovery Manager Database Manager Archive Manager • Result: Schedule. • Not every syntactically correct schedule is semantically correct (i.e., preserves the ACID properties). • Formal description of correct schedules needed. • Application programs send basic operations. • Algorithm sorts these dynamically into a correct schedule.