HOME

TheInfoList



OR:

A precedence graph, also named conflict graph and
serializability In concurrency control of databases,Philip A. Bernstein, Vassos Hadzilacos, Nathan Goodman (1987)''Concurrency Control and Recovery in Database Systems''(free PDF download), Addison Wesley Publishing Company, Gerhard Weikum, Gottfried Vossen (200 ...
graph, is used in the context of
concurrency control In information technology and computer science, especially in the fields of computer programming, operating systems, multiprocessors, and databases, concurrency control ensures that correct results for concurrent operations are generated, while ...
in
database In computing, a database is an organized collection of data stored and accessed electronically. Small databases can be stored on a file system, while large databases are hosted on computer clusters or cloud storage. The design of databases spa ...
s. The precedence graph for a schedule S contains: * A node for each committed transaction in S * An arc from Ti to Tj if an action of Ti precedes and conflicts with one of Tj's actions. That is the actions belong to different transactions, at least one of the actions is a write operation, and the actions access the same object (read or write).


Precedence graph examples


Example 1

:S = \begin T1 & T2 \\ R(A) & R(A) \\ A=A*5 & R(B) \\ W(A) & B=B+A \\ R(B) & W(B) \\ B=B*10 & \\ W(B) & \\ \end


Example 2

:D = R1(A) R2(B) W2(A) Com.2 W1(A) Com.1 W3(A) Com.3 A precedence graph of the schedule D, with 3 transactions. As there is a cycle (of length 2; with two edges) through the committed transactions T1 and T2, this
schedule A schedule or a timetable, as a basic time-management tool, consists of a list of times at which possible tasks, events, or actions are intended to take place, or of a sequence of events in the chronological order in which such things are ...
(history) is ''not'' Conflict serializable. Notice, that the commit of Transaction 2 does not have any meaning regarding the creation of a precedence graph.


Testing Serializability with Precedence Graph

Algorithm to test ''Conflict Serializability'' of a Schedule S along with an example schedule. S = \begin T1 & T2 & T3 \\ R(A) & & \\ & W(A) & \\ & Com. & \\ W(A) & & \\ Com. & & \\ & & W(A)\\ & & Com.\\ \end :or S = R1(A) W2(A) Com.2 W1(A) Com.1 W3(A) Com.3 # For each transaction Tx participating in schedule S, create a node labeled Ti in the precedence graph. Thus the precedence graph contains T1, T2, T3. # For each case in S where Tj executes a ''read_item''(X) after Ti executes a ''write_item''(X), create an edge (Ti → Tj) in the precedence graph. This occurs nowhere in the above example, as there is no read after write. # For each case in S where Tj executes a ''write_item''(X) after Ti executes a ''read_item''(X), create an edge (Ti → Tj) in the precedence graph. This results in a directed edge from T1 to T2 (as T1 has ''R(A)'' before T2 having ''W(A)''). # For each case in S where Tj executes a ''write_item''(X) after Ti executes a ''write_item''(X), create an edge (Ti → Tj) in the precedence graph. This results in directed edges from T2 to T1, T2 to T3 and T1 to T3. # The schedule S is serializable if and only if the precedence graph has no cycles. As T1 and T2 constitute a cycle, the above example is not (conflict) serializable.


References

{{Reflist


External links


The Fundamentals of Database Systems, 5th Edition
the use of precedence graphs is discussed in chapter 17, as they relate to tests for conflict serializability. *
Abraham Silberschatz Avi Silberschatz (born in Haifa, Israel) is an Israeli computer scientist and researcher. He graduated in 1976 with a Ph.D. in Computer Science from the State University of New York (SUNY) at Stony Brook. He became the Sidney J. Weinberg Profe ...
, Henry Korth, and S. Sudarshan. 2005. Database System Concepts (5 ed.), PP. 628–630. McGraw-Hill, Inc., New York, NY, USA. Database management systems el:Γράφος Σειριοποιησιμότητας ru:Граф предшествования