1.事务的概念
事务指逻辑上的一组操作(多个sql语句组成),组成这组操作的各个单元,要么全部成功,要么全部失败。在不同的环境中,都可以有事务。对应在数据库中,就是数据库事务。
2.为什么要用事物
上方的概念有些晦涩难懂,我给大家举个例子来理解一下。
我们现在有一个数据表:
create table accout( id int primary key auto_increment, name varchar(20) comment '账户名称', money decimal(11,2) comment '金额' ); insert into accout(name, money) values ('张三', 5000), ('李四', 1000);
李四觉得这个月1000块不够用,于是向张三借2000块钱。
-- 张三账户减2000 update accout set money=money-2000 where name='张三'; -- 李四账户加2000 update accout set money=money+2000 where name='李四';
当张三刚把钱转给李四时(刚好执行完第一句sql),此时,突然停电了(没来的及运行第二句sql)。这时,张三的账户已经减去了2000块,但是李四账户2000块还没加上(杯具啊)。
这如何是好呢?这时,我们的“事务”站出来了,我们可以把这两句sql写成一个事务,保证这两个数据全部运行成功或者全部运行失败。不会再出现张三把钱扣了,但是李四没有收到钱的情况 。
3.使用
- 1.开启事务:start transaction;
- 2.执行多条SQL语句
- 3.回滚或提交:rollback/commit;
说明:rollback即是全部失败,commit即是全部成功
start transaction; -- 张三账户减少2000 update accout set money=money-2000 where name = '张三'; -- 李四账户增加2000 update accout set money=money+2000 where name = '李四'; commit;
4.事务的原则(ACID)
事务ACID原则: 原子性、一致性、隔离性、持久性 。
4.1原子性(Atomicity)
在化学层面大家都知道,原子是不可再分的。这里的意思与此相似,事务中的语句是不可分的,要么都执行成功,要么都执行失败。就像上方给出的例子,张三给李四转钱,只要把这两句sql放入到事务中,这两句sql就不是在分开执行。
4.2一致性(Consistency)
一直性也很好理解,还用上方的例子,李四要向张三接2000块,我们去扣除张三的余额2000块,但是到了给李四打钱的时候,却只打入1000块,这显然不行,我们必须保证扣除的钱和打入的钱保持一致才可以,这就是一致性。
4.3持久性(Durability)
持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。 相当于李四借完钱了,李四必须承认接了张三的钱,不管什么理由,都没用。
4.4隔离性(Isolation)
隔离性是指并发(多个用户同时操作)的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。
隔离性导致的一些问题
脏读:
指一个事务读取另外一个事务未提交的数据.
不可重复读:
在一个事务内读取表中的某一行数据,多次读取结果不同.
幻读:
是指在一个事务内读取到了别的事务插入的数据,导致前后读取不一致.