Mysql事物
事物这个东西大家应该写过项目的就用过,但是还是要说的
为什么需要事物
现在很多软件都是多用户,多程序,多线程的,对同一张表可能同时有很多人在用,为保持数据的一致性,所以提出了事物的概念...:
事物应该具有4个属性:原子性,一致性,隔离性,持久性.这四个属性通常称为ACID特性;
原子性(atomicity):一个事物是一个不可分隔的工作单位,事物中包括的诸多操作,要么都成功,要么都失败;...一致性(consistency):事物必须是使数据库从一个一致性状态变成另一个一致性状态与原子性是密切相关的;
隔离性(isolation):一个事物的执行不能被其他事物干扰,即一个事物内部的操作及使用... 数据对并发的其他事物是隔离的,并发执行的各个事物之间不能互相干扰;
持久性(durability):持久性也称永久性(permanence),即一个事物一旦提交,他对数据库中数据的改变就应该是永久性的...Mysql事物的默认隔离级别是repeatable read
事物并发问题
脏读:事物A读取了事物B更新的数据,然后B回滚操作,那么A就读取到了脏数据
不可重复读:事物A多次读取同一数据,事物B在事物A