您现在的位置是:首页 >其他 >【MySQL】事务网站首页其他
【MySQL】事务
事务是一组操作的集合,我们将一组操作视为一个整体,所以事务里面的操作的时候要么同时成功,要么同时失败,之所以会有事务也是因为我们在实际生活中会用到
最典型的例子就是转账操作:A向B进行转账,A这边扣款成功的同时B那边一定是收款成功的,如果没有事务的话就会出现A扣款成功但B没有收到款的情况
1.事务的操作
正常提交事务的流程为: 开始事务->执行操作->提交事务
如果出现异常的话则需要回滚事务
开启事务:
begin;
提交事务:
commit;
回滚事务:
rollback;
begin之后加上要执行的SQL语句即可,然后是commit,提交失败则执行rollback
MySQL的事务默认是自动提交的,当执行一条DML语句时MySQL会自动提交事务,如果你想要修改MySQL提交事务的方式
select @@autocommit; 查看事务提交方式(为啥这两个@颜色还不一样呢(⊙_⊙)?)
set @@autocommit=0; 0为手动提交,1为自动提交
2.事务的特性
-
原子性 : 事务是不可分割的最小的操作单元,里面的操作要么全部成功,要么全部失败
-
一致性 : 事务完成的时候必须使所有的数据保持一致状态
-
隔离性 : 数据库系统提供的隔离机制,目的是保证事务在不受外部并发操作影响的环境下运行
-
持久性 : 一个事务一旦被提交,它对数据库中数据所做的改变是永久的
针对隔离性,我们来讲下如果没有隔离性并发事务会造成的问题
3.并发事务的问题
最常见的问题有脏读,不可重复读和幻读
-
脏读:指一个事务读取到另一个事务还未提交的数据,如下图
事务1修改了数据,但是还没有提交,此时事务2对数据进行查询,那么事务2就会查询到已经被修改但是还未提交的数据 -
不可重复读:一个事务先后读取同一条记录,但两次读取出来的结果是不同的,如图
事务1在两次查询期间,事务2对数据进行了修改并提交事务,导致事务1两次查询的数据结果不一致 -
幻读:幻读是在解决不可重复读的基础上出现的新问题,事务在查询某个数据的时候发现数据不存在,于是进行插入数据,但是在插入数据的时候发现数据又存在,就像出现了幻觉一样,如图
由于解决了不可重复度,所以事务1两次select结果均为未找到,但是却无法插入数据
4.事务隔离级别
隔离级别 | 脏读 | 不可重复读 | 幻读 |
---|---|---|---|
读未提交(read uncommited) | × | × | × |
读已提交(read commited) | √ | × | × |
可重复读(repeatable read) | √ | √ | × |
串行化(serializable) | √ | √ | √ |
上述4个级别,串行化隔离级别最高,可以解决所有的并发事务问题,但同时性能也是最差的,这就需要根据实际情况来选择事务的隔离级别了
在MySQL中默认的隔离级别是可重复读
设置事务的SQL语句如下:
select @@tx_isolation; 查看事务隔离级别(个人使用的5.6版本的SQL语句,下面的是高版本的SQL语句)
select @@transaction_isolation;
set [session/global] transaction isolation level 隔离级别; 设置事务隔离级别,set session是仅当前客户端窗口有效,set global则是所有客户端的窗口都有效
MySQL的基础部分到这基本结束了,主要包括基础的SQL语句,MySQL的函数,数据约束,多表查询和这篇的事务,下一篇开始就开始进阶的内容了,完