A dirty read takes no notice of any lock taken by another process. The read is officially “dirty” when it reads data that is uncommitted. This can become problematic if the uncommitted transaction fails or for some other reason is rolled back.
Imagine a scenario in which you are shopping on a website and place an item into your basket and proceed to payment. The site's checkout process decrements the stock by one and starts to charge your card all in the one transaction. At that time, a second unrelated process starts. The website's back office stock interface runs and makes a dirty read of all the product inventory levels, reading the reduced value. Unfortunately, there is a problem with your transaction (insufficient funds), and your purchase transaction is rolled back. The website stock level has now reverted to the original level, but the stock interface has just reported a different value.
Let see following example to understand in detail:
/* SESSION 1 */
BEGIN TRANSACTION; UPDATE Person.Person SET FirstName = 'James' WHERE LastName = 'Jones'; WAITFOR DELAY '00:00:05.000'; ROLLBACK TRANSACTION; SELECT FirstName ,LastName FROM Person.Person WHERE LastName = 'Jones';
/* SESSION 2 */
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; SELECT FirstName ,LastName FROM Person.Person WHERE LastName = 'Jones';
Once Session 1 is running, quickly switch over to a second session and execute the following SQL statement. The SQL in this second session will perform a dirty read. If you time it right and execute this query while the transaction in Session 1 is open (it has not yet been rolled back), then your output will match Figure 1 and every person with a surname of “Jones” now has a first name of “James”:
No comments:
Post a Comment