Concurrency Control Techniques
Concurrency Control Techniques
Concurrency Control Techniques
• Lost Update Problems: The problem occurs when two different database
transactions perform the read/write operations on the same database items
and update the values of the items incorrect.
• Dirty Read Problems: The dirty read problem occurs when one transaction
updates an item of the database, and somehow the transaction fails, and
before the data gets rollback, the updated database item is accessed by
another transaction.
Concurrency Control Protocols
1. Shared lock: Shared lock is also called read lock, used for reading
data items only. They ensure that a record is not in process of being
updated during a read-only request. Shared locks can also be used to
prevent any kind of updates of record. It is denoted by Lock-S.
2. Exclusive lock: With the Exclusive Lock, a data item can be read as
well as written. Also called write lock. An exclusive lock prevents any
other locker from obtaining any sort of a lock on the object. They can be
owned by only one transaction at a time. It is denoted as Lock-X.
Two – Phase Locking (2PL)
• The two-phase locking protocol divides the execution phase of the
transaction into three parts.
• In the first part, when the execution of the transaction starts, it seeks
permission for the lock it requires.
• The third phase is started as soon as the transaction releases its first lock. In
this phase, the transaction cannot demand any new locks. It only releases
the acquired locks.
Two – Phase Locking (2PL)
• Growing phase: In the growing phase, a new lock on the data item may be
acquired by the transaction, but none can be released.
1. Read phase: In this phase, the transaction T is read and executed. It is used
to read the value of various data items and stores them in temporary local
variables. It can perform all the write operations on temporary variables
without an update to the actual database.
2. Validation phase: In this phase, the temporary variable value will be
validated against the actual data to see if it violates the serializability.
3. Write phase: If the validation of the transaction is validated, then the
temporary results are written to the database otherwise the transaction is
rolled back.
References
• Korth, Silbertz and Sudarshan (1998), “Database Concepts”, 4th
Edition, TMH.
• Elmasri and Navathe (2010), “Fundamentals of Database Systems”,
5th Edition, Addision Wesley.
• Date C J,” An Introduction to Database Systems”, 8th Edition,
Addision Wesley.
• M. Tamer Oezsu, Patrick Valduriez (2011). “Principles of
Distributed Database Systems”, 2nd Edition, Prentice Hall.
• https://www.javatpoint.com/dbms-concurrency-control/ last
accessed on 8 October' 2021.