ERP俱乐部
ERP爱好者、ERP从业者互相交流、互相学习的乐园;我们的愿景是成为全球一流的中文ERP(Enterprise Resource Planning)交流平台
网站首页 论坛首页 搜索 用户列表 FAQ 注册 登录  
ERP俱乐部 -> 数据库专栏 -> MS SQL Server数据库 -> 浅谈SQL Sever数据库中事务的ACID特性
  浅谈SQL Sever数据库中事务的ACID特性
帖子发起人: 半神   发起时间: 2012-02-02 11:23 上午   回复数: 0
? 上一主题 下一主题 ?
楼主
  2012-02-02, 11:23 上午
半神 离线,最后访问时间: 2013/6/5 18:59:05 半神

发帖数前25位

超级管理员
职务: 超级管理员
80级
等级: 80级
注册: 2008年1月6日
区域: 华南
经验: 1,267
积分: 1,131
精华: 2
发贴: 590
排名: 26
Site AdministratorsGlobal ModeratorsSite ModeratorsSite Registered Users培训学员(MM学员服务区-北京200708班) 培训学员(FI学员服务区-深圳200805班) 每日发帖之星
浅谈SQL Sever数据库中事务的ACID特性
 
ACID,是指在可靠数据库管理系统(DBMS)中,事务(transaction)所应该具有的四个特性:原子性(Atomicity)、一致性 (Consistency)、隔离性(Isolation)、持久性(Durability).这是可靠数据库所应具备的几个特性.下面针对这几个特性进 行逐个讲解.

  理解原子性(Atomicity)

  原子性意味着数据库中的事务执行是作为原子。即不可再分,整个语句要么执行,要么不执行。

  在SQL SERVER中,每一个单独的语句都可以看作是默认包含在一个事务之中:

浅谈SQL Sever数据库中事务的ACID特性

  所以,每一个语句本身具有原子性,要么全部执行,这么全部不执行,不会有中间状态:

浅谈SQL Sever数据库中事务的ACID特性

  上面说了,每一条T-SQL语句都可以看作是默认被包裹在一个事务之中的,SQL Server对于每一条单独的语句都实现了原子性,但这种原子粒度是非常小的,如果用户想要自己定义原子的大小,则需要包含在事务中来构成用户自定义的原子粒度:

浅谈SQL Sever数据库中事务的ACID特性

  对于用户来说,要用事务实现的自定义原子性往往是和业务相关的,比如银行转账,从A账户减去100,在B账户增加100,如果这两个语句不能保证原子性的话,比如从A账户减去100后,服务器断 电,而在B账户中却没有增加100.虽然这种情况会让银行很开心,但作为开发人员的你可不希望这种结果.而默认事务中,即使出错了也不会整个事务进行回 滚。而是失败的语句抛出异常,而正确的语句成功执行。这样会破坏原子性。所以SQL SERVER给予了一些选项来保证事务的原子性.

  SQL SERVER提供了两大类方式来保证自定义事务的原子性:

  1.通过SET XACT_ABORT ON来设置事务必须符合原子性

  利用设置XACT_ABORT选项设置为ON,来设置所有事务都作为一个原子处理.下面例子利用两个语句插入到数据库,可以看到开启SET XACT_ABORT ON选项后,事务具有了原子性:

浅谈SQL Sever数据库中事务的ACID特性

  2.按照用户设置进行回滚(ROLLBACK)

  这种方式具有更高的灵活性,开发人员可以自定义在什么情况进行ROLLBACK,利用TRY CATCH语句和@@ERROR进行判断都属于这种方式.

浅谈SQL Sever数据库中事务的ACID特性


开源时代的到来,对与技术人员是一个巨大的考验



QQ:876162454


分享按钮 IP 地址: 已登录   来自: 已登录    返回顶部
 第 1 页 总共 1 页 [共有 1 条记录]
ERP俱乐部 -> 数据库专栏 -> MS SQL Server数据库 -> 浅谈SQL Sever数据库中事务的ACID特性
(C)Copyright 2005-2020 www.erpclub.org All Rights Reserved.
Tel:+86-755-26444630
Email:webmaster@yok.com.cn