History (transaction processing)
A history (which corresponds to a complete schedule , see section Schedule and Schuffle Product ) is used in computer science in the field of database theory to describe an execution plan for the parallel execution of several transactions (see also transaction system ), which specifies the order in which the transaction operations are executed. The possible types of transaction operations include read and write operations, and the scheduling operations Commit (successful completion of the transaction) and Abort (termination of the transaction). The history is therefore a designation for the execution order of all operations of the parallel executed transactions.
Schedule and shuffle product
The term schedule should also be mentioned in connection with history. A schedule is a so-called prefix of a history. In this context, the prefix means: the first to the nth element of the history. A complete schedule therefore corresponds to a history. A (formal) example of a schedule would be:
The following elements are given:
- : Data objects in a database
- : a transaction executed in parallel
- : Read operation of the transaction on the object
- : Write operation of the transaction on the object
- : Commit operation of the transaction (successful completion of the transaction)
- : Abort operation of the transaction (termination of the transaction)
- : one of i possible histories for up to
- : a schedule of history
For the parallel execution of 3 transactions ( ) one of the possible histories ( ), with its write operations ( ) and read operations ( ) on the objects ( ) and the associated commit operations ( ) and abort operations ( ), looks like this:
- history
A possible schedule ( ), in this case the complete schedule, for this history would be:
- Schedule
Another possible schedule ( ) (incomplete) for this history would be:
- Schedule
Another possible schedule ( ) (incomplete) for this history would be:
- Schedule
There are of course other histories for the parallel execution of the three transactions, e.g. B. if we simply postpone the two operations of the third transaction:
- history
The set of all possible combinations of read and write operations, but without the commit and abort operations, is called the shuffle product . If we take our second history ( ) as the basis, then the element ( ) from the set of shuffle products ( ) would be:
A closer look reveals that the combination of read and write operations remains the same, but the commit and cancel operations have been removed.
Serial and non / serializable histories, correctness criterion "serializability"
In addition to the representation of certain execution sequences of the operations, histories serve to define (and are the basis for checking) the serializability of these execution sequences.
Imagine the following transactions on an account:
- : Withdraw 100, - € from account no. 777980.
- : Pay 52, - € into account no. 777980.
comprises a read operation to read in the account balance and a write operation to modify the account balance. Same goes for . A total of four operations have to be carried out for these two transactions. A history now defines the order in which these operations are processed. The most obvious solution would be to execute the transactions one after the other (" serially "), for example all operations from and then all operations from . Such a history is called a serial history .
A problem arises when the serial execution of transactions is inefficient. For example, when a whole series of transactions has to wait because the first transaction is waiting for user input. In some cases the strict sequential execution is not necessary at all, e.g. B. when the transactions work on completely different data objects, or only perform read operations. In this case, we get a low transaction throughput rate (completed transactions per unit of time). In order to increase the transaction throughput, histories are also permitted in transaction systems in which several transactions are so-called "active" at the same time. Active means that a transaction can start executing before the current transactions are completed, and operations on subsequent transactions can be performed before the current transactions are completed. Such a concurrent history is correct if it delivers the same results as a serial history.
Formally, a correctness criterion serializability can be defined for the concurrent execution of transactions: A history can be serialized if it is equivalent to a serial history . The order of the transactions in is then called the serialization order. It is important that the relative order of conflicting operations (e.g. two write operations) in the history corresponds to the serialization order of the associated transactions. Conflicting operation means that two operations in different transactions access the same data object and at least one of the operations involved is a write operation.
Totally and partially ordered histories
Since the order does not matter for some operations, histories define i. A. No total order on all operations, but only a partial order, which primarily determines the relative order of conflicting operations. Such partial orders can be represented with the help of a directed graph:
In the history presented here, a read operation of the transaction on an object is recorded as , while a write operation from to is recorded as . The arrows indicate the relative order of conflicting operations. The history shown here cannot be serialized.
Individual evidence
- ^ Theo Härder and Erhard Rahm: Database systems, concepts and techniques of implementation , 2nd edition (2001), page 413
- ↑ Theo Härder and Erhard Rahm: Database systems, concepts and techniques of implementation , 2nd edition (2001)
literature
- Alfons Kemper, André Eickler: Database systems . Oldenbourg , 2004, ISBN 3-486-25706-4 .
- Theo Härder, Erhard Rahm: Database systems, concepts and implementation techniques . Springer , Berlin 2001, ISBN 3-540-42133-5 .

