浙江大学数据库系统概念PPT第十六章 对应原版教材第五版
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
If a lock cannot be granted, the requesting transaction is made to wait till all incompatible locks held by other transactions have been released. The lock is then granted.
Any number of transactions can hold shared locks on an item, but if any transaction holds an exclusive on the item no other transaction may hold any lock on the item.
Basically, how to generate a correct (serializable) schedule?
Database System Concepts 3rd Edition
16.4
©Silberschatz, Korth and Sudarshan, Bo Zhou
Pitfalls of Lock-Based Protocols
T2: lock-S(A); read (A); unlock(A); lock-S(B); read (B); unlock(B); display(A+B)
Locking as above is not sufficient to guarantee serializability — if A and B get updated in-between the read of A and B, the displayed sum would be wrong.
Database System Concepts 3rd Edition
16.1
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols
A lock is a mechanism to control concurrent access to a data item Data items can be locked in two modes : 1. exclusive (X) mode. Data item can be both read as well as
Chapter 16: Concurrency Control
Lock-Based Protocols Multiple Granularity Deadlock Handling Insert and Delete Operations Concurrency in Index Structures
Database System Concepts 3rd Edition
16.3
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols (Cont.)
Example of a transaction performing locking:
Cons源自文库der the partial schedule
Neither T3 nor T4 can make progress — executing lock-S(B) causes T4 to wait for T3 to release its lock on B, while executing lock-X(A) causes T3 to wait for T4 to release its lock on A. Such a situation is called a deadlock. To handle a deadlock one of T3 or T4 must be rolled back
and its locks released.
Database System Concepts 3rd Edition
16.5
©Silberschatz, Korth and Sudarshan, Bo Zhou
Pitfalls of Lock-Based Protocols (Cont.)
The potential for deadlock exists in most locking protocols. Deadlocks are a necessary evil. Starvation is also possible if concurrency control manager is badly designed. For example:
written. X-lock is requested using lock-X instruction. 2. shared (S) mode. Data item can only be read. S-lock is
requested using lock-S instruction. Lock requests are made to concurrency-control manager. Transaction can proceed only after request is granted.
A locking protocol is a set of rules followed by all transactions while requesting and releasing locks. Locking protocols restrict the set of possible schedules.
Database System Concepts 3rd Edition
16.2
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols (Cont.)
Lock-compatibility matrix
A transaction may be granted a lock on an item if the requested lock is compatible with locks already held on the item by other transactions
Any number of transactions can hold shared locks on an item, but if any transaction holds an exclusive on the item no other transaction may hold any lock on the item.
Basically, how to generate a correct (serializable) schedule?
Database System Concepts 3rd Edition
16.4
©Silberschatz, Korth and Sudarshan, Bo Zhou
Pitfalls of Lock-Based Protocols
T2: lock-S(A); read (A); unlock(A); lock-S(B); read (B); unlock(B); display(A+B)
Locking as above is not sufficient to guarantee serializability — if A and B get updated in-between the read of A and B, the displayed sum would be wrong.
Database System Concepts 3rd Edition
16.1
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols
A lock is a mechanism to control concurrent access to a data item Data items can be locked in two modes : 1. exclusive (X) mode. Data item can be both read as well as
Chapter 16: Concurrency Control
Lock-Based Protocols Multiple Granularity Deadlock Handling Insert and Delete Operations Concurrency in Index Structures
Database System Concepts 3rd Edition
16.3
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols (Cont.)
Example of a transaction performing locking:
Cons源自文库der the partial schedule
Neither T3 nor T4 can make progress — executing lock-S(B) causes T4 to wait for T3 to release its lock on B, while executing lock-X(A) causes T3 to wait for T4 to release its lock on A. Such a situation is called a deadlock. To handle a deadlock one of T3 or T4 must be rolled back
and its locks released.
Database System Concepts 3rd Edition
16.5
©Silberschatz, Korth and Sudarshan, Bo Zhou
Pitfalls of Lock-Based Protocols (Cont.)
The potential for deadlock exists in most locking protocols. Deadlocks are a necessary evil. Starvation is also possible if concurrency control manager is badly designed. For example:
written. X-lock is requested using lock-X instruction. 2. shared (S) mode. Data item can only be read. S-lock is
requested using lock-S instruction. Lock requests are made to concurrency-control manager. Transaction can proceed only after request is granted.
A locking protocol is a set of rules followed by all transactions while requesting and releasing locks. Locking protocols restrict the set of possible schedules.
Database System Concepts 3rd Edition
16.2
©Silberschatz, Korth and Sudarshan, Bo Zhou
Lock-Based Protocols (Cont.)
Lock-compatibility matrix
A transaction may be granted a lock on an item if the requested lock is compatible with locks already held on the item by other transactions