技术开发 频道

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

  【IT168 技术】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特性

0
相关文章