Mysql的事务&事务的特征&事务的隔离级别

事务

事务的概念:

事务(Transaction)是数据库区别于文件系统的重要特性之一,事务就是用户定义的一系列执行SQL语句的操作, 这些操作要么完全地执行,要么完全地都不执行, 它是一个不可分割的工作执行单元。

事务的使用场景:

在日常生活中,有时我们需要进行银行转账,这个银行转账操作背后就是需要执行多个SQL语句,假如这些SQL执行到一半突然停电了,那么就会导致这个功能只完成了一半,这种情况是不允许出现,要想解决这个问题就需要通过事务来完成。

事务的(ACID)特征

原子性(Atomicity):
整个事务的所有操作要么全部提交成功,要么全部失败回滚(不会出现部分执行的情况)。

一致性(Consistency):
几个并行执行的事务,其执行结果必须与按某一顺序串行执行的结果相一致。

隔离性(Isolation):
事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务必须是透明的。(和事务的隔离级别有关联)

持久性(Durability):
一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作

事务的隔离级别

未提交读: 脏读(READ UNCOMMITTED)

  • 读取到其他事务还未提交的数据
  • 例:初始count=100,B事务把count修改为101,但是还没有commit提交到数据库,可能由于回滚并没有真正保存到数据库,但是A事务此时就读取到了101

提交读: 不可重复读(READ COMMITTED)

  • 同一个事务两次读取到的数据时其他事务提交前后的,所以读取数据不一样
  • 例:A先读取到数据count=100,但是B事物把count修改成了101,A这个事物还没有完成,在此读取时发现同一个事物两次。 读取的数据不一样

可重复读: 幻读(REPEATABLE READ)
这是MySQL的默认事务隔离级别

  • 在读取数据时加一个版本号,如果其他事务修改了这个数据,我还是会读取我以前读取那个版本的数据,不会管他修改后的数据
  • 但并不能阻止另一个事务插入新的数据行,这就会导致该事务中凭空多出数据行,像出现了幻读一样,这便是幻读问题
  • 例:A事务读取count=100后加了一个版本号,如果后续B事务将 count修改成了101,A事务不会读取最新版本的101,而是读取自己最初读取的那个版本100

可串行读(SERIALIZABLE)

  • 这是事务的最高隔离级别,通过强制事务排序,使之不可能相互冲突就是在每个读的数据行加上共享锁来实现
  • 在该隔离级别下,可以解决前面出现的脏读、不可重复读和幻读问题,但也会导致大量的超时和锁竞争现象,一般不推荐使用。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值