MySQL——事务的基本操做

在数据库中,事务是指一组逻辑操做单元,使数据从一种状态变换到另外一种状态。数据库

为确保数据库中数据的一致性,事务的操做应该是流畅完成的,中间不能失败,一旦有操做失败,那么回滚到开始事务的状态。
图片描述并发

事务的特色(ACID)

  • 原子性:指事务是一个不可分割的工做单位,事务中的操做要么都发生,要么都不发生
  • 一致性:事务必须使数据库从一个一致性状态变换到另外一个一致性状态。(数据不被破坏)
  • 隔离性:一个事务的执行不能被其余事务干扰,一个事务内部的操做及使用的数据对并发的事务也是隔离的。每个事务都存在一个事务空间,彼此不干扰
  • 持久性:一个事务一旦被提交,它对数据库的改变就是永久性的,接下来的其余操做和数据库故障不该该对其有任何影响

事务控制的语言

  • [ begin ]:开启一个事务,开启一个新的事务空间
  • [ commit ]:提交事务
  • [ rollback ]:回滚事务

图片描述
每次begin开启一个事务后,选择commit和rollback结束本次事务。要从新begin开启一个新的事务。spa


事务的并发问题

存在五种问题:脏读、不可重复读、幻读、第一类丢失更新、第二类丢失更新
隔离级别:不一样的隔离级别能够处理不一样的并发问题
默认的隔离级别为:repreatable read
MySQL默认状况下不会出现幻读和第一类丢失更新
图片描述3d

第一类丢失更新(回滚丢失)

图片描述

第二类丢失更新(覆盖丢失)

图片描述

不可重复读

图片描述

幻读

图片描述

脏读

图片描述
MySQL使用锁机制来解决第二类丢失更新
悲观锁:版本控制

select ......for update;

乐观锁:使用版本控制code

相关文章
相关标签/搜索