SELECT 语句的默认事务锁定行为 SET TRANSACTION ISOLATION LEVEL
来源:互联网 发布:法国帅哥知乎 编辑:程序博客网 时间:2024/05/18 00:28
SET TRANSACTION ISOLATION LEVEL
控制由连接发出的所有 Microsoft® SQL Server™ SELECT 语句的默认事务锁定行为。
语法
SET TRANSACTION ISOLATION LEVEL
{ READ COMMITTED
| READ UNCOMMITTED
| REPEATABLE READ
| SERIALIZABLE
}
参数
READ COMMITTED
指定在读取数据时控制共享锁以避免脏读,但数据可在事务结束前更改,从而产生不可重复读取或幻像数据。该选项是 SQL Server 的默认值。
READ UNCOMMITTED
执行脏读或 0 级隔离锁定,这表示不发出共享锁,也不接受排它锁。当设置该选项时,可以对数据执行未提交读或脏读;在事务结束前可以更改数据内的数值,行也可以出现在数据集中或从数据集消失。该选项的作用与在事务内所有语句中的所有表上设置 NOLOCK 相同。这是四个隔离级别中限制最小的级别。
REPEATABLE READ
锁定查询中使用的所有数据以防止其他用户更新数据,但是其他用户可以将新的幻像行插入数据集,且幻像行包括在当前事务的后续读取中。因为并发低于默认隔离级别,所以应只在必要时才使用该选项。
SERIALIZABLE
在数据集上放置一个范围锁,以防止其他用户在事务完成之前更新数据集或将行插入数据集内。这是四个隔离级别中限制最大的级别。因为并发级别较低,所以应只在必要时才使用该选项。该选项的作用与在事务内所有 SELECT 语句中的所有表上设置 HOLDLOCK 相同。
注释
一次只能设置这些选项中的一个,而且设置的选项将一直对那个连接保持有效,直到显式更改该选项为止。这是默认行为,除非在语句的 FROM 子句中在表级上指定优化选项。
SET TRANSACTION ISOLATION LEVEL 的设置是在执行或运行时设置,而不是在分析时设置。
示例
下例为会话设置 TRANSACTION ISOLATION LEVEL。对于每个后续 Transact-SQL 语句,SQL Server 将所有共享锁一直控制到事务结束为止。
SET TRANSACTION ISOLATION LEVEL REPEATABLE READGOBEGIN TRANSACTIONSELECT * FROM publishersSELECT * FROM authors...COMMIT TRANSACTION
- SELECT 语句的默认事务锁定行为 SET TRANSACTION ISOLATION LEVEL
- SELECT 语句的默认事务锁定行为 SET TRANSACTION ISOLATION LEVEL
- SET TRANSACTION ISOLATION LEVEL
- SET TRANSACTION ISOLATION LEVEL
- 事务的隔离级别1 (TRANSACTION ISOLATION LEVEL)
- 事务的隔离级别2 (TRANSACTION ISOLATION LEVEL)
- SET Transaction Isolation Level Read语法的四种情况
- SET Transaction Isolation Level Read语法的四种情况
- SET Transaction Isolation Level Read语法的四种情况
- SET Transaction Isolation Level Read语法的四种情况
- SET Transaction Isolation Level Read语法的四种情况
- [转]SET TRANSACTION ISOLATION LEVEL (Transact-SQL)
- SET TRANSACTION ISOLATION LEVEL (Transact-SQL)
- SET TRANSACTION ISOLATION LEVEL (Transact-SQL)
- SET TRANSACTION ISOLATION LEVEL (Transact-SQL)
- innodb_locks_unsafe_for_binlog && transaction isolation level
- Transaction, Lock, Isolation Level
- Transaction Isolation Level
- 字符串转换为数字:String:convert a string to int
- 从数组中查找出最大最小两数的log(n)算法
- SELECT 语句的默认事务锁定行为 SET TRANSACTION ISOLATION LEVEL
- Java正则表达式详解
- 在创新中崛起
- SELECT 语句的默认事务锁定行为 SET TRANSACTION ISOLATION LEVEL
- DLL(动态连接库)创建和使用
- (转)LINK : warning LNK4098: 默认库“LIBCMTD”与其他库的使用冲突;请使用 /NODEFAULTLIB:library
- 释放vector内存的两种方法
- 让虚拟机实现开机自动后台运行
- LAMP(Linux+Apache+MySQL+PHP)服务器的性能优化
- SQL Server 2000数据库 [置疑] 的解决方法
- java的原子操作和volatile
- 基础代码汇总整理 for NOIP 2009 修订版(下)