4. 两次更新问题(Second lost updates problem):无法重复读取特例,有两个并发事务同时读取同一行数据然后其中一个对它进行修改提交而另一个也进行了修改提交这会造成第一次写操作失效(可以不进行考虑,学习优先级低)
  5. 幻读(Phantom Reads):也称为幻像(幻影)。是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。 同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后会发生操作第一个事务的用户发现表中还有没有修改的数据行,好象 发生了幻觉一样。例如,一个编辑人员更改作者提交的文档,但当生产部门将其更改内容合并到该文档的主复本时,发现作者已将未编辑的新材料添加到该文档中。 如果在编辑人员和生产部门完成对原始文档的处理之前,任何人都不能将新材料添加到文档中,则可以避免该问题。
  为了避免上面出现几种情况在标准SQL规范中定义了4个事务隔离级别,不同隔离级别对事务处理不同 。
  1.未授权读取(Read Uncommitted):也称未提交读,会出现脏读、不可重复读、幻读 ( 隔离级别低,并发性能高 )。(在读数据时不会检查或使用任何锁。因此,在这种隔离级别中可能读取到没有提交的数据。)允许脏读取但不允许更新丢失,如果一个事务已经开始写数据则另外一个数据则不允许同时进行写操作但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。事务隔离的低级别,仅可保证不读取物理损坏的数据。它允许读取已经被其它用户修改但尚未提交确定的数据。
  2. 授权读取(Read Committed):也称提交读,会出现不可重复读、幻读问题(锁定正在读取的行)。( 只读取提交的数据并等待其他事务释放排他锁。读数据的共享锁在读操作完成后立即释放)允许不可重复读取但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现,读取数据的事务允许其他事务继续访问该行数据,但是未提交写事务将会禁止其他事务访问该行。SQL Server 默认的级别。在此隔离级下,SELECT 命令不会返回尚未提交(Committed) 的数据,也不能返回脏数据。
  3. 可重复读取(Repeatable Read):禁止不可重复读取和脏读取,会出幻读(锁定所读取的所有行)。但是有时可能出现幻影数据,这可以通过“共享读锁”和“排他写锁”实现,读取数据事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。在此隔离级下,用SELECT 命令读取的数据在整个命令执行过程中不会被更改。此选项会影响系统的效能,非必要情况好不用此隔离级。
  4. 串行(Serializable):也称可串行读或者可序列化,保证所有的情况不会发生(锁表)。提供严格的事务隔离,它要求事务序列化执行,事务只能一个接着一个地执行,但不能并发执行。如果仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作事务访问到,通过表级排他锁直接锁表来实现。事务隔离的高级别,事务之间完全隔离。如果事务在可串行读隔离级别上运行,则可以保证任何并发重叠事务均是串行的。