Transactions specify an
isolation level that defines the degree to which one transaction must be
isolated from resource or data modifications made by other transactions.
Isolation levels are described in terms of which concurrency side-effects, such
as dirty reads or phantom reads, are allowed.
Transaction
isolation levels control:
·
Whether locks are taken when data is read, and what type of
locks are requested.
·
How long the read locks are held.
·
Whether a read operation referencing rows modified by another
transaction:
o
Blocks until the exclusive lock on the row is freed.
o
Retrieves the committed version of the row that existed at the
time the statement or transaction started.
o
Reads the uncommitted data modification.
Controls the locking and row versioning
behavior of Transact-SQL statements issued by a connection to SQL Server.
READ UNCOMMITTED:
Specifies
that statements can read rows that have been modified by other transactions but
not yet committed.
Transactions
running at the READ UNCOMMITTED level do not issue shared locks to prevent
other transactions from modifying data read by the current transaction. READ
UNCOMMITTED transactions are also not blocked by exclusive locks that would
prevent the current transaction from reading rows that have been modified but
not committed by other transactions. When this option is set, it is possible to
read uncommitted modifications, which are called dirty reads. Values in the
data can be changed and rows can appear or disappear in the data set before the
end of the transaction. This option has the same effect as setting NOLOCK on
all tables in all SELECT statements in a transaction. This is the least
restrictive of the isolation levels.
In
SQL Server, you can also minimize locking contention while protecting
transactions from dirty reads of uncommitted data modifications using either:
·
The READ COMMITTED isolation level with the
READ_COMMITTED_SNAPSHOT database option set to ON.
·
The SNAPSHOT isolation level.
READ COMMITTED:
Specifies that statements cannot read
data that has been modified but not committed by other transactions. This
prevents dirty reads. Data can be changed by other transactions between
individual statements within the current transaction, resulting in
nonrepeatable reads or phantom data. This option is the SQL Server default.
The behavior of READ COMMITTED depends
on the setting of the READ_COMMITTED_SNAPSHOT database option:
If READ_COMMITTED_SNAPSHOT is set to OFF
(the default), the Database Engine uses shared locks to prevent other
transactions from modifying rows while the current transaction is running a
read operation. The shared locks also block the statement from reading rows
modified by other transactions until the other transaction is completed. The
shared lock type determines when it will be released. Row locks are released
before the next row is processed. Page locks are released when the next
page is read, and table locks are released when the statement finishes.
Note:
If
READ_COMMITTED_SNAPSHOT is set to ON, the Database Engine uses row versioning
to present each statement with a transactionally consistent snapshot of the
data as it existed at the start of the statement. Locks are not used to protect
the data from updates by other transactions.
Snapshot isolation
supports FILESTREAM data. Under snapshot isolation mode, FILESTREAM data read
by any statement in a transaction will be the transactionally consistent
version of the data that existed at the start of the transaction.
When the READ_COMMITTED_SNAPSHOT
database option is ON, you can use the READCOMMITTEDLOCK table hint to request
shared locking instead of row versioning for individual statements in
transactions running at the READ COMMITTED isolation level.
REPEATABLE READ:
Specifies that statements cannot read
data that has been modified but not yet committed by other transactions and
that no other transactions can modify data that has been read by the current
transaction until the current transaction completes.
SNAPSHOT:
Specifies that data read by any
statement in a transaction will be the transactionally consistent version of
the data that existed at the start of the transaction. The transaction can only
recognize data modifications that were committed before the start of the
transaction. Data modifications made by other transactions after the start of
the current transaction are not visible to statements executing in the current
transaction. The effect is as if the statements in a transaction get a snapshot
of the committed data as it existed at the start of the transaction.
SERIALIZABLE:
Specifies
the following:
·
Statements cannot read data that has been modified but not yet
committed by other transactions.
·
No other transactions can modify data that has been read by the
current transaction until the current transaction completes.
·
Other transactions cannot insert new rows with key values that
would fall in the range of keys read by any statements in the current
transaction until the current transaction completes.
Syntax:
SET TRANSACTION ISOLATION LEVEL
{ READ UNCOMMITTED
| READ COMMITTED
| REPEATABLE READ
| SNAPSHOT
| SERIALIZABLE
}
[ ; ]
Ex:
SET TRANSACTION ISOLATION LEVEL
READ COMMITTED
How to find current Isolation level
using DMVs?
select
transaction_isolation_level,* from sys.dm_exec_sessions where session_id=@@SPID
Trasaction_Isolation_level
1=READ
UNCOMMITTED
2=READ
COMMITTED
3=REPEATABLE
READ
4=SERIALIZABLE
5=SNAPSHOT
No comments:
Post a Comment