KEMBAR78
DB 3 4 | PDF | Database Transaction | Acid
0% found this document useful (0 votes)
35 views15 pages

DB 3 4

A transaction is a unit of program execution that accesses and updates data items, utilizing operations like read and write. The ACID properties (Atomicity, Consistency, Isolation, Durability) ensure the integrity and reliability of transactions, particularly in concurrent executions where issues like failures and inconsistencies can arise. Various scheduling methods, including serial and concurrent schedules, are used to manage transaction execution while maintaining data consistency, with conflict serializability being a key concept in determining if a schedule can be rearranged to preserve consistency.

Uploaded by

amaJin me
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
35 views15 pages

DB 3 4

A transaction is a unit of program execution that accesses and updates data items, utilizing operations like read and write. The ACID properties (Atomicity, Consistency, Isolation, Durability) ensure the integrity and reliability of transactions, particularly in concurrent executions where issues like failures and inconsistencies can arise. Various scheduling methods, including serial and concurrent schedules, are used to manage transaction execution while maintaining data consistency, with conflict serializability being a key concept in determining if a schedule can be rearranged to preserve consistency.

Uploaded by

amaJin me
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 15

Transaction Concept

A transaction is a unit of program execution that accesses and possibly updates various data items.
In a database transaction, two basic operations are used to access and change data:
1.read(X): 2. write(X):
 This operation moves the data item X from the  This operation moves the updated value of X
database (on disk) into a variable X in the from the transaction’s memory (buffer) back to
transaction’s memory (a buffer in the computer’s the database on the disk.
main memory).  This is how changes made to X during the
 The transaction can now work with X from the transaction are saved to the database.
buffer.

Example: Transaction to transfer $50 from account A to account B:


Get the balance of account A.
Subtract $50 from account A.
Save the new balance of A back to the DB.
Get the balance of account B.
Add $50 to account B.
Save the new balance of account B.

ACID properties of this Transaction


1. Atomicity requirement
a. If a failure happens in the middle of the transaction such as after subtracting $50 from A but before adding
it to B (after step 3 and before step 6), the system might show $950 in A and $2000 in B, which means $50
is "lost" from the system. This would leave the database in an inconsistent state.
b. Atomicity ensures that either the whole transaction happens (A has $950 and B has $2050) or none of it
happens (A stays at $1000 and B at $2000). The system undoes partial changes to maintain consistency.
2. Consistency requirement
a. The total sum of A and B should remain the same after the transaction. Without this rule, money could be
accidentally created or destroyed by the transaction. If the database is consistent before the execution of
the transaction, it should stay consistent after.
b. Ensuring consistency is the responsibility of the programmer who writes the transaction.
3. Durability requirement
a. Once the user has been notified that the transaction has completed (the transfer of $50 has taken place),
the updates to the database by the transaction must be permanent. Even if the system crashes later, the
updates to A and B must not be lost.
b. The system ensures this by writing the changes to the disk before the transaction finishes or keeping
enough information to redo the transaction after a restart.
c. The recovery system of the database, is responsible for ensuring durability, atomicity
4. Isolation requirement
a. If multiple transactions are running at the same time, they shouldn’t affect each other while in progress.
For example, while transferring $50 from A to B, the database might be temporarily inconsistent (A shows
$950, but B still shows $2000). If another transaction reads A and B at that moment, it might see incorrect
values. Isolation ensures that that no other transaction sees this inconsistency.
b. Running transactions one after the other would avoid this issue, but running them concurrently (at the
same time) is faster and more efficient, so databases use special methods to handle this.
T1 T2
1. read(A)
2. A := A – 50
3. write(A)
read(A), read(B), print(A+B)
4. read(B)
5. B := B + 50
6. write(B)
Main Issues with Transactions:
1. Failures: Transactions can fail because of system crashes, hardware failures, or other issues. If a failure happens
during the transfer, the database might end up in an inconsistent state.
2. Concurrent Execution: If multiple transactions happen at the same time, they might interfere with each other
and cause problems, like showing incorrect balances.

ACID Properties
A transaction is a unit of program execution that accesses and possibly updates various data items. This collection
of steps must appear to the user as a single, indivisible unit. To preserve the integrity of data the database system
must ensure:

1. Atomicity. All operations of the transaction are completed, or none are. This prevents partial updates.
2. Consistency. Execution of a transaction in isolation preserves the consistency of the database.
In above example: The sum of A and B is unchanged by the execution of the transaction. In general,
consistency requirements include
i. Explicitly specified integrity constraints such as primary keys and foreign keys
ii. Implicit integrity constraints
e.g., the total balance of all accounts minus loan amounts must match the cash on hand.
A transaction, when starting to execute, the database must be in a consistent state.
During transaction execution the database may be temporarily inconsistent.
When the transaction completes successfully the database must be consistent again.
Mistakes in the transaction logic can lead to inconsistency.

3. Isolation: Even though multiple transactions may execute at the same time, the system guarantees that, for
every pair of transactions Ti and Tj, it appears to Ti that either Tj finished execution before Ti started or Tj
started execution after Ti finished. Thus, each transaction is unaware of other transactions executing at the
same time in the system.
4. Durability. After a transaction completes successfully, the changes it has made to the database are
permanent, even if there are system failures.

Transaction State
We need to be more precise about what we mean by successful completion of a transaction. We therefore
establish a simple abstract transaction model. A transaction must be in one of the following states:
 Active – the initial state; the transaction stays in this state while it is executing
 Partially committed – after the final statement has been executed.
 Failed – after the discovery Something went wrong, and the transaction can't finish.
 Aborted – Transaction has been rolled back and the database restored to its state prior to the start of the
transaction. Two options after it has been aborted:
 Restart the transaction- can be done only if no internal logical error. (transaction’s logic)
 Kill the transaction
 Committed – after successful completion, and its changes are saved.
Sometimes a transaction may not finish successfully. This is called an aborted transaction. To maintain atomicity,
an aborted transaction must not affect the database. Any changes made by the transaction are undone, a process
called rollback.
A recovery system manages this by keeping a log of every change. The log records details like the transaction ID,
the data item being changed, its old value, and its new value. This way, if something goes wrong, the system can
undo the changes (rollback) or reapply them if needed (redo), ensuring both atomicity and durability.
When a transaction finishes successfully, it is committed, meaning its changes are saved permanently. If the
system fails afterward, the changes will still remain. A committed transaction cannot be undone by aborting it. To
reverse its effects, a new compensating transaction must be created, such as subtracting $20 if a previous
transaction added $20. However, compensating transactions are not always possible and must be handled by the
user, not the database.
If a failure occurs that prevents the transaction from continuing, it enters the failed state. In this case, the system
rolls back the transaction, undoing its changes, and the transaction moves to the aborted state. From there, the
system has two choices:
 Restart the transaction: This is possible if the failure was caused by a hardware or software error that
wasn’t the fault of the transaction’s logic.
 Terminate the transaction: This happens if there’s a deeper logical error, bad input, or missing data, which
may require rewriting the application.

Concurrent Executions (Transaction isolation)


Transaction systems often allow multiple transactions to run at the same time, which can create issues with keeping
data consistent. It would be easier to run them one after another (serially), but there are two main reasons to allow
transactions to run concurrently:
1. Increased processor and disk utilization: (better transaction throughput)
a. A transaction consists of many steps. Some involve tasks like reading/writing data (I/O) and others
involve using the CPU. The CPU and disks can work at the same time.
b. For example, while one transaction is reading or writing data on a disk, another can be running in the
CPU, and yet a third transaction can use a different disk. This parallel processing increases the number
of transactions completed in a given time (throughput), and makes better use of the CPU and disks,
keeping them busy.

2. Reduced average response time:


a. If transactions run one after another, shorter transactions may have to wait for longer ones to finish,
causing unpredictable delays.
b. If the transactions don’t affect the same part of the database, it's better to run them concurrently, so
they can share CPU and disk time. This leads to fewer delays and quicker completion times overall
(lower average response time).

Concurrency control schemes – mechanisms to achieve isolation


 However, when transactions run at the same time, the isolation property can be violated, leading to
inconsistencies in the database even if each transaction is correct by itself.
 To prevent this, the database system uses concurrency-control schemes to control the interaction among the
concurrent transactions in order to prevent them from destroying the consistency of the database.
Schedules

Transactions and Schedules:


 A transaction is a set of operations performed on the database. Each transaction can read or write data.
 A schedule is the sequence in which multiple transactions are executed.
Schedule is a sequence of instructions that specify the chronological order in which instructions of concurrent
transactions are executed
 A schedule for a set of transactions must consist of all instructions of those transactions
 Must preserve the order in which the instructions appear in each individual transaction.

A transaction that successfully completes its execution will have a commit instruction as the last statement
A transaction that fails to successfully complete its execution will have an abort instruction as the last statement
Account A = $1000
Account B has $2000. There are two transactions:
T1 moves $50 from account A to account B.
T2 takes 10% of the amount in account A and moves it to account B.

Schedule 1 (Serial Schedule)


 A serial schedule runs transactions one after another. No transaction starts until the previous one finishes. This
ensures consistency because each transaction works on the database without interference from others.
 Example: In Figure 14.2, you see two transactions, T1 runs first, completes, and then T2 runs, making sure the
sum of A + B is correct.

Schedule 2 A serial schedule in which T2 is followed by T1


Schedule 3
 A concurrent schedule allows transactions to run at the same time or in overlapping intervals (overlap with
each other). This improves system efficiency but can lead to complications if not managed properly.
 Figure 14.4 shows an example of a concurrent schedule where the instructions of T1 and T2 are interleaved
(mixed). However, this concurrent execution is still equivalent to Schedule 1 in terms of the result: the final
state of accounts A and B is correct.

Schedule 4

 This concurrent schedule does not preserve the sum of “A + B”


 A schedule can be inconsistent if the order of execution leads to errors in the database, like incorrect final values.
 Figure 14.5 shows an inconsistent schedule. The transactions run concurrently, but the final state of accounts A
and B is incorrect because $50 was lost due to poor coordination between the transactions.

Serializability
Serial Schedules: If transactions run one after another in sequence (serially), they're guaranteed to maintain data
consistency. But in real life, transactions often overlap or run at the same time to improve system efficiency.
 Basic Assumption – Each transaction preserves database consistency.
 Thus, serial execution of a set of transactions preserves database consistency.

For a concurrent schedule it's harder to tell if the database remains consistent. The key idea is to ensure that a
concurrent schedule has the same result as if the transactions were run serially.
 A (possibly concurrent) schedule is serializable if it is equivalent to a serial schedule. Different forms of
schedule equivalence give rise to the notions of:
1. conflict serializability
2. view serializability

Simplified view of transactions


a) Instead of looking at every operation, we mainly care about read and write instructions
b) Only the read and write actions affect whether a schedule is serializable (safe and consistent).
c) We assume that between a read(Q) and a write(Q) a transaction may perform an arbitrary sequence of
operations on the copy of the data which is in the local buffer of the transaction.
d) Our simplified schedules consist of only read and write instructions.

Conflicting Instructions
Let’s consider two transactions, T₁ and T₂, and each one has a step, I and J, that happens one after the other.
If I and J work on different data items, then we can swap I and J without affecting the results. But if I and J work on
the same data item (let's call it Q), the order of these 2 steps might affect the result.

1. I = read(Q), J = read(Q). I and J, don’t conflict. Since the same value of Q is read by T₁ and T₂
2. l = read(Q), J = write(Q). They conflict.
3. I = write(Q), J = read(Q). They conflict
4. l = write(Q), J = write(Q). They conflict

Intuitively, a conflict between I and J forces them to happen in a specific order.


If I and J are consecutive in a schedule and they do not conflict, we can switch their order without changing the result.

1. If a schedule S can be turned into a schedule S´ by swapping non-conflicting actions, then S and S´ are called
conflict equivalent.
2. We say that a schedule S is conflict serializable if it is conflict equivalent to a serial schedule
(A schedule is conflict serializable if it can be rearranged into a serial schedule by swapping non-conflicting actions.)

3. Schedule 3 can be turned into Schedule 6 (a serial schedule where T2 happens after T1, by swapping non-conflicting
instructions.) Therefore, Schedule 3 is conflict serializable.

Example of a schedule that is not conflict serializable:

We are unable to swap instructions in the side schedule to obtain either the
serial schedule < T3, T4 >, or the serial schedule < T4, T3 >.

This schedule consists of only the significant operations (that is, the read and write) of transactions T3 and T4. This
schedule is not conflict serializable, since it is not equivalent to either the serial schedule or the serial schedule.

Precedence Graph
A precedence graph helps determine if a schedule (a series of transaction operations) is conflict serializable,
meaning that it can be converted into a serial schedule (where transactions run one after the other) without
conflict.
1. Consider some schedule of a set of transactions T1, T2, ..., Tn
2. Precedence graph: a direct graph where the vertices (nodes) are the transactions that are the part of the schedule.
3. We draw an arc from Ti to Tj if the 2 transactions conflict, and Ti accessed the data item on which the conflict
arose earlier.
4. We may label the arc by the item that was accessed. Example,

How to Use the Precedence Graph:


 If there is an edge between T₁ and T₂, this means that T₁ must fully
execute
before T₂ starts.
 If the graph has no cycles (meaning no loops or closed paths), then
the
schedule is conflict serializable

Topological Sorting is the process of rearranging the transactions to follow the precedence graph's order. If this sorting works
without cycles, the schedule is conflict serializable.

Testing for Conflict Serializability


We can check if a schedule is conflict serializable using something called a
topological sort. For example, in Figure a, the graph can be arranged into two
possible orders, as shown in Figures b and c.

1. A schedule is conflict serializable if and only if its precedence graph is acyclic.

2. Use a cycle detection algorithm to see if there’s a loop (cycle) in the graph. If
there’s a cycle, the schedule is not conflict serializable. These algorithms, such
as depth-first search, take about n² operations to run, where n is the number
of transactions/Vertices.
a.(Better algorithms take order n + e where e is the number of edges.)
3. If precedence graph is acyclic, the serializability order can be obtained by
doing a topological sort of the graph.
a. This means arranging the graph in a in a straight line (or sequence)
that follows the order shown in the precedence graph.
b. For example, a serializability order for the schedule (a) would be one
of either (b) or (c)

Recoverable Schedules
1. A recoverable schedule means that if one transaction (Tj) reads data written
by another transaction (Ti), then the commit operation of Ti commit (finish)
before the commit operation of Tj.
This makes sure that Tj is working with the final, correct version of the data.
2. The schedule 9 is not recoverable because T7 commits immediately after reading data A. It doesn’t wait to see
if T6, which wrote A, commits or fails.

3. If T6 fails or aborts, we have a problem because T7 has already used T6's data. T7 is now dependent on T6 and
has possibly shown incorrect data to users. To avoid this issue, database must ensure that schedules are
recoverable, meaning transactions should commit in the right order

Cascading Rollbacks
1. Cascading rollback happens when a single transaction failure leads to a
series of transaction rollbacks. Consider the following schedule where none
of the transactions has yet committed (so the schedule is recoverable)
If T fails, T and T must also be rolled back.
10 11 12
2. This can result in a lot of work being undone, which can be very inefficient.

Transaction rollback is the process of undoing/reversing a transaction in a database when an error or failure occurs.
Cascading rollback happens when one transaction failure causes multiple other transactions to be undone.

Cascadeless Schedules
1. Cascadeless schedules – In a cascadeless schedule, if a transaction Tj reads a
data that was written by another transaction Ti, then the commit operation of
Ti must appear before the read operation of Tj.
2. Every cascadeless schedule is also recoverable, meaning it’s easier to manage
failures.
3. It’s ideal to use cascadeless schedules to avoid issues like cascading rollbacks.
4. An example of a schedule that is not cascadeless

example of a schedule that is not cascadeless

Concurrency Control

Lock-Based Protocols
To ensure isolation, one way is to make sure that only one transaction can access a data item at a time. This means
that while one transaction is using a data item, no other transaction can modify it. The most common way to
enforce this is by using locks. A transaction can only access a data item only if it currently holding a lock on that
item.
There are two main types of locks for data items:
1. Shared (S) mode: If a transaction has a shared lock on a data item, it can only read the item but cannot change
(write) it. Data item can only be read. S-lock is requested using lock-S instruction.

2. Exclusive (X) mode: If a transaction has an exclusive lock on a data item, it can both read and write the item.
Data item can be both read as well as written. X-lock is requested using lock-X instruction.

A lock is a mechanism to control concurrent access to a data item. Lock requests are made to CCM. Transaction can
proceed only after request is granted.

A transaction can get a lock on an item only if the type of lock it wants is compatible with the locks that other
transactions already have on that item.
 Many transactions can hold shared locks on the same item at the same time.
 If one transaction has an exclusive lock on an item, no other transaction can have any lock on that item

"true" if the two lock types can work together.


“false” a shared lock is not compatible with an exclusive lock.

To request a shared lock on a data item Q, a transaction uses the


command lock-S(Q).
For an exclusive lock, it uses lock-X(Q).
To release a lock, the transaction uses the command unlock(Q).
Deadlock
Deadlock Example
In the example of T3 and T4, neither can move forward:
 T3 holds an exclusive lock on B and T4 is trying to get a shared lock on B. This
means T4 is waiting for T3 to unlock B.
 At the same time, T4 holds a shared lock on A and T3 is trying to get an exclusive
lock on A. Now, T3 is waiting for T4 to unlock A.
Because both transactions are waiting for each other, neither can move forward. This
situation is called a deadlock.
To fix it, one of the transactions (either T3 or T4) must be rolled back, releasing its
locks so the other transaction can continue.

Deadlocks and Starvation


1. Deadlocks can happen in most locking systems. They’re unavoidable in many cases but can be managed by
rolling back one of the transactions.
2. Starvation is another issue. This happens if the concurrency control system is poorly designed. For example, if a
transaction is waiting for an X-lock on an item, but other transactions keep getting an S-lock on the same item.
The first transaction may keep getting pushed back or even rolled back repeatedly due to deadlocks. his
situation is called starvation because T1 never gets the lock it needs.
3. To prevent starvation, locks can be granted in this way:
If no other transaction has a conflicting lock on the item.
If no other transaction that requested a lock before this one is still waiting.

Two-Phase Locking (2PL)


It is a system that ensures that the transactions will behave in a way that appears as though they were run one
after the other (serializable), meaning they don’t interfere with each other. It works in two phases:

1. Phase 1: Growing Phase – A transaction can obtain locks but cannot release any.
2. Phase 2: Shrinking Phase – A transaction can release locks but cannot obtain any new ones.

However, two-phase locking does not guarantee that deadlocks won’t happen.
Enhanced Locking Systems
To prevent certain problems like deadlocks or cascading rollbacks (where one failure triggers multiple rollbacks),
the following extensions to two-phase locking exist:
1. Strict Two-Phase Locking: A transaction must hold onto all its exclusive locks until it either completes
(commits) or fails (aborts). This ensures recoverability and prevents cascading rollbacks.
2. Rigorous Two-Phase Locking: A transaction must hold onto all locks (both shared and exclusive) until it either
commits or aborts. This ensures that transactions can be serialized in the order in which they commit.

Most databases use rigorous two-phase locking but just call it two-phase locking.
Serializability Without Two-Phase Locking
a) Deadlocks are handled by rolling back one of the transactions.
b) Starvation can occur but can be prevented with better design.
c) Two-Phase Locking helps ensure that transactions don’t interfere with each other but
doesn’t guarantee freedom from deadlocks. Various extensions improve safety and
recoverability.

1. Two-phase locking isn't always needed for serializability: There are some schedules
that can be conflict-serializable without using the two-phase locking method.

2. Without extra information (like order of accessing data), two-phase locking is


important for conflict serializability in this way: If we have a transaction Ti that
doesn't use two-phase locking, we can find another transaction Tj that does use it,
along with a schedule for both Ti and Tj that isn't conflict-serializable.

Deadlock Handling
A deadlock happens when every transaction in a group is waiting for another transaction in
the same group, so none of them can continue.

Deadlock Prevention
Deadlock prevention protocols ensure deadlocks never happen by using different strategies:
1. Pre-declaration: Requires that a transaction locks all the data it needs before starting.
2. Graph-based protocol: Orders data items and makes sure transactions can only lock data
items in the order specified by the partial order (graph-based protocol).

More Deadlock Prevention Strategies


1. Wait-Die Scheme (non-preemptive):
a) Older transaction may wait for younger one to release data item.
b) Younger transactions never wait for older ones; they are rolled back instead.
c) A transaction may die several times before acquiring a lock

2. Wound-Wait Scheme (preemptive):


a) Older transaction can wound (forces rollback) of younger transaction instead of waiting for it.
b) Younger transactions may wait for older ones.
c) Fewer rollbacks than wait-die scheme.

In both schemes, if a transaction is rolled back, it keeps its original timestamp when restarted. This ensures that
older transactions are given priority, preventing starvation (where a transaction never gets to run).

Timeout-Based Schemes:
a) A transaction waits for a lock only for a set amount of time.
b) If the wait time is exceeded, the transaction is rolled back.
c) This helps resolve deadlocks if they occur, as transactions will eventually time out.
d) Pros: Simple to implement.
e) Cons: Transactions may be rolled back even when there’s no deadlock, leading to unnecessary work. Also,
it's hard to pick the right timeout value, and starvation can still happen.
Concurrency Control
1. A database must provide a mechanism that will ensure that all possible schedules are both:
a. Conflict serializable.
b. Recoverable and preferably cascadeless
2. A policy in which only one transaction can execute at a time generates serial schedules, but provides a poor
degree of concurrency
3. Concurrency-control schemes tradeoff between the amount of concurrency they allow and the amount of
overhead that they incur
4. Testing a schedule for serializability after it has executed is a little too late!
a. Tests for serializability help us understand why a concurrency control protocol is correct
5. Goal – to develop concurrency control protocols that will assure serializability.

Weak Levels of Consistency


1. Some applications are willing to live with weak levels of consistency, allowing schedules that are not serializable
a. E.g., a read-only transaction that wants to get an approximate total balance of all accounts
b. E.g., database statistics computed for query optimization can be approximate (why?)
c. Such transactions need not be serializable with respect to other transactions
2. Tradeoff accuracy for performance

Levels of Consistency in SQL-92

1. Serializable — default
2. Repeatable read — only committed records to be read, repeated reads of same record must return same value.
However, a transaction may not be serializable – it may find some records inserted by a transaction but not find
others.
3. Read committed — only committed records can be read, but successive reads of record may return different
(but committed) values.
4. Read uncommitted — even uncommitted records may be read.
5. Lower degrees of consistency useful for gathering approximate
information about the database
6. Warning: some database systems do not ensure serializable schedules by default
E.g., Oracle and PostgreSQL by default support a level of consistency called snapshot isolation (not part of the
SQL standard)

Transaction Definition in SQL

1. Data manipulation language must include a construct for specifying the set of actions that comprise a
transaction.
2. In SQL, a transaction begins implicitly.
3. A transaction in SQL ends by:
a. Commit work commits current transaction and begins a new one.
b. Rollback work causes current transaction to abort.
4. In almost all database systems, by default, every SQL statement also commits implicitly if it executes
successfully
a. Implicit commit can be turned off by a database directive
E.g. in JDBC, connection.setAutoCommit(false);

Other Notions of Serializability

View Serializability
a) Let S and S´ be two schedules with the same set of transactions. S and S´ are view equivalent if the following
three conditions are met, for each data item Q,
1) If in schedule S, transaction Ti reads the initial value of Q, then in schedule S’ also transaction Ti must
read the initial value of Q.
2) If in schedule S transaction Ti executes read(Q), and that value was produced by transaction Tj (if any),
then in schedule S’ also transaction Ti must read the value of Q that was produced by the same
write(Q) operation of transaction Tj .
3) The transaction (if any) that performs the final write(Q) operation in schedule S must also perform the
final write(Q) operation in schedule S’.
b) As can be seen, view equivalence is also based purely on reads and writes alone.

1. A schedule S is view serializable if it is view equivalent to a serial schedule.


2. Every conflict serializable schedule is also view serializable.
3. Below is a schedule which is view-serializable but not conflict serializable.

4. What serial schedule is above equivalent to?


5. Every view serializable schedule that is not conflict serializable has blind writes.

Test for View Serializability


1. The precedence graph test for conflict serializability cannot be used directly to test for view serializability.
a. Extension to test for view serializability has cost exponential in the size of the precedence graph.
2. The problem of checking if a schedule is view serializable falls in the class of NP-complete problems.
a. Thus, existence of an efficient algorithm is extremely unlikely.
3. However, practical algorithms that just check some sufficient conditions for view serializability can still be used.

More Complex Notions of Serializability


1. The schedule below produces the same outcome as the serial schedule < T1, T5 >, yet is not conflict equivalent or
view equivalent to it.

2. If we start with A = 1000 and B = 2000, the final result is 960 and 2040
3. Determining such equivalence requires analysis of operations other than read and write.

You might also like