应用场景:
银行取钱,从ATM机取钱,分为以下几个步骤
1 登陆ATM机,输入密码;
2 连接数据库,验证密码;
3 验证成功,获得用户信息,比如存款余额等;
4 用户输入需要取款的金额,按下确认键;
5 从后台数据库中减掉用户账户上的对应金额;
6 ATM吐出钱;
7 用户把钱拿走。
对于上面的取钱这个事情,如果有一步出现错误的话,那么就会取消整个取钱的动作,但是如果在第5步,系统后台已经把钱减了,但是ATM机没有取出来,那么就应用到mysql中的事务。简单地
来说,就是取钱这7步要么都完成,要么就啥也不做,在数据库中就是这个道理。
事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位,事务回滚是指将该事务已经完成的对数据库的更新操作撤销,在事务中,每个正确的原子操作都会被顺序执行,直到遇到错误的原子操作。回滚的意思其实即使如果之前是插入操作的话,那么会执行删除之前插入的记录,如果是修改操作的话,那么会执行将update之前的记录还原。因此,正确的原子操作是真正被执行过的,是物理执行。
事务是由一条或者多条sql语句组成,在事务的操作中,要么这些sql语句都执行,要么都不执行。
事务的ACID特性:原子性,一致性,隔离性,持久性。
在当前事务中确实能看到插入的记录,最后只不过被删除了,但是auto_increament不会删除而是