mysql事务
数据库事务
1.什么是事务
事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。
事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交。
如果其中一个步骤失败,将会停止,不再读取后面的代码,但是之前正确的代码会被存储在内存中,下次开启事务时会提交内存中的代码
总结:事物就是一组操作,要么全部完成,要么全部失败!
3.事务的过程
开启事务后会在内存中执行代码,提交事务后将数据更新入物理内存中.
当一个事务中存在着错误时,在之前执行正确代码的数据会留在内存中
当再次开启事务时,会进行提交操作,把之前的数据更新入物理内存.
回滚数据就是将内存中的数据清除
2.事物特性 ACID
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性 (事物内的操作,要么全部成功,要么全部失败)
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性 (事物之前之后,前后数据的一致性)
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态 如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
3 、隔离性(多个事物时,相互不能干扰)
隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。
即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。
4 、持续性(一旦事物提交(commit)之后,是不可回滚的)
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
转账操作
有如下表
+----+--------+-------+ | id | name | money | +----+--------+-------+ | 1 | 向北 | 1500 | | 2 | 杨枭 | 2500 | +----+--------+-------+
事务
start transaction; -- 开始事务 update biao1 set money = money - 500 where id = '1'; update biao1 set money = money + 500 where id = '2'; commit; -- 提交事务 -- rollback; -- 回滚事务
执行后的结果
+----+--------+-------+ | id | name | money | +----+--------+-------+ | 1 | 向北 | 1000 | | 2 | 杨枭 | 3000 | +----+--------+-------+