数据库事务的级别

原创 2011年01月19日 23:42:00

1.read uncommitted(脏读)(读取正在提交的数据)

   read uncommitted(又称读取未提交内容)允许任务读取数据库中未提交的数据更改。

 

 测试脚本:

  1.   创建表

CREATE TABLE [dbo].[testTb](
 [ID] [int] NULL,
 [Name] [char](20) NULL
)  

 

  2.建立 事务A:插入数据

    begin tran
    insert into testTb values(5,'e')

    waitfor delay '00:00:10'

    commit;

 3.建立事务B:读取数据

    set transaction isolation level read uncommitted
    begin tran

    select * from testTb


   commit;

4.运行事务A立即运行事务B,此时事务A还没有提交,而事务B可以读取事务A正在提交的数据

 

2.read committed(提交读)(不能读取正在提交的数据)  

  级别Read Committed(又称读取已提交内容)可防止脏读。该级别查询只读取已提交的数据更改。如果事务需要读取被另一未完成事务 修改的数据,该事务将等待,直到第一个事务完成(提交或回退)。

 

CREATE TABLE [dbo].[testTb](
 [ID] [int] NULL,
 [Name] [char](20) NULL
)  

 

  2.建立 事务A:插入数据

    begin tran
    insert into testTb values(5,'e')

    waitfor delay '00:00:10'

    commit;

 3.建立事务B:读取数据

   set transaction isolation level read committed
   begin tran

   select * from testTb
   commit

4.运行事务A立即运行事务B,此时事务A还没有提交,而事务B必须等到事务A完成后才可以读取数据

 

3.REPEATABLE READ(可重复读)(读取数据是不能修改)
  

  指定语句不能读取已由其他事务修改但尚未提交的行,并且指定,其他任何事务都不能在当前事务完成之前修改由当前事务读取的数据。

CREATE TABLE [dbo].[testTb](
 [ID] [int] NULL,
 [Name] [char](20) NULL
)  

 

  2.建立 事务A:更新数据

    begin tran
    update testTb set Name='CV' where ID='8'

    waitfor delay '00:00:10'

    commit;

 3.建立事务B:读取数据

   set transaction isolation level repeatable read

   begin tran

   select * from testTb
   commit

4.运行事务A立即运行事务B,此时事务A还没有提交,而事务B必须等到事务A完成后才可以读取数据

 

4.SERIALIZABLE(顺序读)(读取数据是不可插入或修改)

  • 语句不能读取已由其他事务修改但尚未提交的数据。
  • 任何其他事务都不能在当前事务完成之前修改由当前事务读取的数据。
  • 在当前事务完成之前,其他事务不能使用当前事务中任何语句读取的键值插入新行。

CREATE TABLE [dbo].[testTb](
 [ID] [int] NULL,
 [Name] [char](20) NULL
)  

 

  2.建立 事务A:更新数据和插入数据

  begin tran
insert into testTb values(9,'d')

update testTb set Name='CV' where ID='8'

waitfor delay '00:00:010'

commit;

 3.建立事务B:读取数据

  set transaction isolation level  level serializable
begin tran

select * from testTb


commit;

4.运行事务A立即运行事务B,此时事务A还没有提交,而事务B必须等到事务A完成后才可以读取数据

SQL事务的四种隔离级别

在SQL标准中定义了四种隔离级别,每一种级别都规定了一个事务中所做的修改,哪些是在事务内和事务间可见的,哪些是不可见的。较低级别的隔离通常可以执行更高的并发,系统的开销也更低。 未提交读(Rea...
  • kai161
  • kai161
  • 2014年09月22日 19:16
  • 9537

linux系统的7种运行级别

本文转载自http://blog.chinaunix.net/uid-22746363-id-383989.html Linux系统有7个运行级别(runlevel) 运行级别0:系统停机状态,系...
  • ccfxue
  • ccfxue
  • 2016年10月09日 16:20
  • 2739

logback 配置不同级别日志输出

logback节点配置详解请参考:http://www.cnblogs.com/DeepLearing/p/5663178.html  配置不同级别日志输出模板如下: ...
  • fanzhigang0
  • fanzhigang0
  • 2017年03月31日 16:50
  • 4300

mysql事物级别详解

SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的。低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销。 Read Uncommitted(...
  • lb520999
  • lb520999
  • 2014年06月20日 13:31
  • 565

更改MySQL的默认事务隔离级别

Mysql的事务隔离级别一共有四个: 大多数的数据库系统的默认事务隔离级别都是:Read committed 而Mysql的默认事务隔离级别是:Repeatable Read 我们可以采用下面这种方法...
  • u012712087
  • u012712087
  • 2015年06月07日 17:45
  • 22632

Linux(三) 运行级别

Linux——04 — 运行级别一、Linux运行级别 0: 关机 1: 单用户 2: 无网络的多用户 3: 命令行模式 4: 未用 5: GUI(图形桌面 模式) 6 : 重启 运行级别的切换 i...
  • chou_out_man
  • chou_out_man
  • 2017年11月03日 21:41
  • 339

深入分析事务的隔离级别

本文详细介绍四种事务隔离级别,并通过举例的方式说明不同的级别能解决什么样的读现象。并且介绍了在关系型数据库中不同的隔离级别的实现原理。 文章转载于http://www.hollischuang....
  • lanxinglan
  • lanxinglan
  • 2016年07月19日 10:14
  • 2334

nginx日志级别

这一系列的文章还是在09年写的,存在电脑里很久了,现在贴出来。顺序也不记得了,看到那个就发那个吧,最近都会发上来。欢迎转载,但请保留链接:http://lenky.info/,谢谢。 第一:打开deb...
  • fangletian1981
  • fangletian1981
  • 2013年12月10日 17:18
  • 3832

Logger日志级别说明及设置方法、说明

日志记录器(Logger)是日志处理的核心组件。log4j具有5种正常级别(Level)。日志记录器(Logger)的可用级别Level (不包括自定义级别 Level), 以下内容就是摘自log4j...
  • hai330
  • hai330
  • 2017年06月23日 17:33
  • 226

关于log日志级别的使用经验

软件中总免不了要使用诸如 Log4net, Log4j, Tracer 等东东来写日志,不管用什么,这些东东大多是大同小异的,一般都提供了这样5个日志级别:     × Debug     × I...
  • yan_dk
  • yan_dk
  • 2014年06月02日 19:36
  • 6671
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据库事务的级别
举报原因:
原因补充:

(最多只允许输入30个字)