Skip to content

Transactions ​

Transaction

A transaction is a logical unit of work. It works as follows:

  • A transaction is started
  • Queries and Updates are performed.
  • Transaction is committed or aborted. If the transaction is committed the changes are finalized in the database, if it is aborted the database is restored to it's state when the transaction was started.

Transactions in JDBC ​

Default in JDBC is to commit after every statement, every statment is a separate transaction.

to commit a transaction with multiple statements:

java
con.setAutoCommit(false);
// execute statements
con.commit();
// or
con.rollback();

Transactions in SQL ​

sql
BEGIN TRANSACTION;
-- execute statements
COMMIT;
-- or
ROLLBACK;

ACID

DBMS guarantee that transactions:

  • are Atomic: either all effects or none.
  • maintain Consistency: leaves db in correct state.
  • are Isolated: a transaction cannot be influenced by other transactions that are running at the same time.
  • are Durable: once the db declares a transaction finished, it's effects will not get lost.

Schedule of transactions ​

Notation ​

Transaction 1Transaction 2Operation
a: = read account Ar1(A)
b: = read account Br1(B)
a: = read account Ar2(A)
out a-200 into account Aw1(A)
b:= read account Br2(B)
out a+500 into account Aw2(A)
put b-500 into account Bw2(B)
put b+200 into account Bw1(B)

can be written as a Schedule: r1(A)r1(B)r2(A)w1(A)r2(B)w2(A)w2(B)w1(B)c1c2

  • r1(A): transaction 1 reads the field A.
  • c1: transaction 1 is commited.

Interleaving ​

The goal of a dbms regarding transaction handling is to:

  • guarantee ACID
  • perform interleaving (for performace and concurrency)

the key is to determine which schedules guarantee isolation.

Transaction operations. ​

Serial schedules ​

serial schedule

A serial schedule for two transactions T1 and T2, can be either running the entire T1 first then the entire T2. or running the complete T2 and then T1.

This type of schedule is always correct and guarantees Isolation.

Any other schedule should be equivalent with a serial schedule.

Commutative Operations:

  • W1(A)−>W2(B): different data items.
  • R1(A)−>R2(B): both are reads.

Conflicting Operations:

  • R1(A)−>W2(A)
  • W1(A)−>R2(A)
  • W1(A)−>W2(A)