博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql事务隔离级别
阅读量:6001 次
发布时间:2019-06-20

本文共 997 字,大约阅读时间需要 3 分钟。

Transaction Isolation Levels

InnoDB支持SQL1992标准中的四种隔离级别:READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE。默认的隔离级别是REPEATABLE READ。

通过SET TRANSACTION命令可以改变默认的隔离级别,为了让这种改变对所有用户的所有连接都生效,需要加上--transaction-isolation选项。

InnoDB通过不同的加锁策略来实现不同的隔离级别

REPEATABLE READ

这是InnoDB默认的隔离级别。在一个事务中,一致读会读到该事务中第一次读到的那个快照。这就意味着,在同一个事务中多次执行普通的SELECT语句返回的结果是一致的。

对于加锁读(SELECT ... FOR UPDATE或者SELECT ... LOCK IN SHARE MODE)、更新、删除语句,锁取决于语句是否使用了唯一索引或者范围类的检索条件。

  • 对于用唯一索引作为检索条件,InnoDB只会锁发现的索引记录,而不会锁它前面的间隙
  • 对于其它的检索条件,InnoDB锁定扫描的索引范围,用间隙锁或者next-key锁来阻塞其它会话向这个范围内的间隙中插入数据

 

 

参考 https://dev.mysql.com/doc/refman/5.7/en/innodb-transaction-isolation-levels.html

 


 事务的特性

  • 原子性:事务中的操作要么全部成功,要么全部失败
  • 一致性:事务操作必须是将数据库从一个一致性状态带到另一个一致性状态。所谓一致指的是,比如转账,A和B都有100元,转账之前总共是200元,转账之后必须也是200元
  • 隔离性:事务之间不会相互影响
  • 持久性:事务提交以后对数据库所做的改变将永久保存下来

事务并发带来的问题

  • 脏读:一个事务读到另一个事务未提交的数据
  • 幻读:一个事务读到另一个事务已提交的数据,然而这种提交的数据涉及到整个表,比如插入和删除,看起来好像幻觉一样
  • 不可重复读:一个事务中多次读取同一个数据返回的结果不一样

事务隔离级别

  • 读未提交:允许一个事务看到另一个事务没有提交的数据
  • 读已提交:允许一个事务看到另一个事务已提交的数据
  • 可重复读:同一个事务中多次读取看到的数据始终一致
  • 串行化:并发事务串行执行

 

转载地址:http://eebmx.baihongyu.com/

你可能感兴趣的文章
UWP Composition API - 锁定列的FlexGrid
查看>>
[转载] win10进行端口转发
查看>>
利用JavaScript jQuery实现图片无限循环轮播(不借助于轮播插件)-----转载
查看>>
从零开始搭建vue项目 请求拦截器 响应拦截器
查看>>
ajax实现动态下拉框
查看>>
HDU3257 Hello World!【打印图案+位运算】
查看>>
jquery 选择器
查看>>
The secret code
查看>>
Makefile 多目录自动编译
查看>>
学习笔记:Oracle dul数据挖掘 导出Oracle11G数据文件坏块中表中
查看>>
统一Matlab下不同子图的色标colorbar
查看>>
Linux 进程间通信(二) 管道
查看>>
Ajax保留浏览器历史的两种解决方案(Hash&Pjax)
查看>>
深入浅出JQuery (二) 选择器
查看>>
CI框架 -- 驱动器
查看>>
FastMQ V0.2.0 stable版发布
查看>>
对象复制
查看>>
Mongodb内嵌数组的完全匹配查询
查看>>
MyBatis学习笔记(四) 注解
查看>>
什么是数据仓库主题
查看>>