数据库之事务
一、概述
数据库事务是指作为单个逻辑工作单位执行的一系列操作。事务处理可以确保非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。
二、事务的ACID性质1、原子性
一个事务对数据库的所有操作,是一个不可分割的工作单元。这些操作要么全部执行,要么什么也不做。
2、一致性
一个事务独立执行的结果,应保持数据库的一致状态。在相关数据库中,所有股则都必须应用于事务的修改,以保持所有数据的完整性。
3、隔离性
在多个事务并发执行时,系统应保证与这些事务先后单独执行时的结果一样,此时程事务达到了隔离性的要求。也就是在多个事务并发执行时,保证执行结果是正确的,如 同单用户环境一样。
4、持久性
一个事务一旦完成全部操作后,它对数据库的所有更新应永久地反映在数据库中,不会丢失。即使以后系统发生故障也是如此。
三、事务的三种模型1、隐式事务是指每一条数据操作语句都自动地成为一个事务,每个事务都有显式的开始和结束标记。
2、显式事务是指有显式的开始和结束标记的事务,事务的开始是隐式的,事务的结束有明确的标记。
3、自动事务是系统自动默认的,开始和结束不用标记。
四、事务的语句 1、开始事物:BEGINTRANSACTION
2、提交事物:COMMITTRANSACTION
3、回滚事务:ROLLBACK TRANSACTION
简单地说,事务是一种机制,防止数据意外丢失和不一致数据的产生,用以维护数据库的完整性,以保证整个系统饿正常进行。