关系型数据库遵循ACID规则
事务(transaction)和现实世界中的交易行为很类似,它有如下四个特性:
1、A (Atomicity) 原子性
原子性是指事务里的所有操作要么全部做完,要么都不做,事务成功的条件是事务里的所有操作都成功,只要有一个操作失败,整个事务就失败,数据需要回滚到执行指令前的状态。比如银行转账,从A账户转100元至B账户,分为两个步骤:(1)从A账户取100元;(2)存入100元至B账户。这两步要么一起完成,要么一起不完成,如果只完成第一步,第二步失败,A账户中的钱会莫名其妙减少100元。
2、C (Consistency) 一致性
一致性是指事务的执行使数据从一个状态转换为另一个状态,但是对于整个数据的完整性保持稳定。
3、I (Isolation) 隔离性
所谓隔离性是指并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。比如现有有个交易是从A账户转100元至B账户,在这个交易还未完成的情况下,如果此时B查询自己的账户,是看不到新增加的100元的
4、D (Durability) 持久性
持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。