事务: 事务指一组sql语句,事务处理是一种机制,用来管理必须成批执行的SQL操作,保证数据库不包含不完整的操作结果。利用事务处理,可以保证一组操作不会中途停止,它们要么完全执行,要么完全不执行。如果没有错误发生,整组语句提交给数据库表;如果发生错误,则进行回退,将数据库恢复到某个已知且安全的状态。
事务的四大特性(ACID)如下
1. 原子性(Atomicity): 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚
2. 一致性(Consistency): 一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态。例如,银行账户A和B分别有存款5000,一共10000,无论A转账给B,还是B转账给A,两个账户的总额总是为10000
3. 隔离性(Isolation): 隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。
4. 持久性(Durability): 持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。
事务处理的几个术语:
回退(rollback): 指撤销指定sql语句的过程;事务处理用来管理 insert、update和 delete语句。不能回退 select语句(回退 select语句也没有必要),也不能回退 create或 drop操作。事务处理中可以使用这些语句,但进行回退时,这些操作也不撤销。
提交(commit): 指将未存储的sql语句结果写入数据库表
保留点(savepoint): 指事务处理中设置的临时占位(placeholder),可以对它发布回退(与回退整个事务处理不同)