事务指定一个隔离级别,该隔离级别定义一个事务必须与由其他事务进行的资源或数据更改相隔离的程度。隔离级别从允许的并发副作用(例如,
脏读或
幻读)的角度进行描述。
选择
事务隔离级别不影响为保护数据修改而获取的锁。事务总是在其修改的任何数据上获取排他锁并在事务完成之前持有该锁,不管为该事务设置了什么样的隔离级别。对于读取操作,事务隔离级别主要定义保护级别,以防受到其他事务所做更改的影响。
较低的隔离级别可以增强许多用户同时访问数据的能力,但也增加了用户可能遇到的并发副作用(例如脏读或丢失更新)的数量。相反,较高的隔离级别减少了用户可能遇到的并发副作用的类型,但需要更多的系统资源,并增加了一个事务阻塞其他事务的可能性。应平衡应用程序的
数据完整性要求与每个隔离级别的开销,在此基础上选择相应的隔离级别。最高隔离级别(可
序列化)保证事务在每次重复读取操作时都能准确检索到相同的数据,但需要通过执行某种级别的锁定来完成此操作,而锁定可能会影响多用户系统中的其他用户。最低隔离级别(未提交读)可以检索其他事务已经修改、但未提交的数据。在未提交读中,所有并发副作用都可能发生,但因为没有读取锁定或
版本控制,所以开销最少。
控制隔离数据以供一个进程使用并防止其它进程干扰的程度的
事务属性。设置隔离级别定义了 SQL Server 会话中所有 SELECT 语句的默认锁定行为。
读脏数据:一事务对数据进行了增删改,但未提交,有可能
回滚,另一事务却读取了未提交的数据
不可重复读:一
事务对数据进行了更新或删除操作,另一事务两次查询的数据不一致
这意味着这种隔离级别可以保证读取的是已经提交过的数据,并且可以实现
可重复读,