X
活动推荐

阿里云高性能云主机2折293元/年

企业级性能云服务器限时2折起
新用户5折爆款服务器会场
查看详情 293元/年
阅读模式:

mysql共享锁和排他锁详解

查看:5794  回复:0  类型:  来源:cnblogs-java攻城狮  标签 mysql

        mysql锁机制分为表级锁行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁排他锁进行分享交流。

        共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。

        排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁的事务是可以对数据就行读取和修改。

        对于共享锁大家可能很好理解,就是多个事务只能读数据不能改数据,对于排他锁大家的理解可能就有些差别,我当初就犯了一个错误,以为排他锁锁住一行数据后,其他事务就不能读取和修改该行数据,其实不是这样的。排他锁指的是一个事务在一行数据加上排他锁后,其他事务不能再在其上加其他的锁。mysql InnoDB引擎默认的修改数据语句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类型,如果加排他锁可以使用select  ...for update语句,加共享锁可以使用select ... lock in share  mode语句。所以加过排他锁的数据行在其他事务种是不能修改数据的,也不能通过for updatelock in share  mode锁的方式查询数据,但可以直接通过select ...from...查询数据,因为普通查询没有任何锁机制。

说了这么多,咱们来看下以下简单的例子:

我们有如下测试数据

mysql共享锁和排他锁详解

 

现在我们对id=1的数据行排他查询,这里会使用begin开启事务,而不会看见我关闭事务,这样做是用来测试,因为提交事务或回滚事务就会释放锁。

打开一个查询窗口

mysql共享锁和排他锁详解

 

会查询到一条数据,现在打开另一个查询窗口,对同一数据分别使用排他查和共享锁查询两种方式查询

排他查

mysql共享锁和排他锁详解

共享查

mysql共享锁和排他锁详解

我们看到开了排他锁查询和共享锁查询都会处于阻塞状态,因为id=1的数据已经被加上了排他锁,此处阻塞是等待排他锁释放。

如果我们直接使用以下查询呢

mysql共享锁和排他锁详解

我们看到是可以查询到数据的。

我们再看一下一个事务获取了共享锁,在其他查询中也只能加共享锁或不加锁。

mysql共享锁和排他锁详解

mysql共享锁和排他锁详解

mysql共享锁和排他锁详解

我们看到是可以查询数据的,但加排他锁就查不到,因为排他锁与共享锁不能存在同一数据上。

最后我们验证下上面说的mysql InnoDb引擎中update,delete,insert语句自动加排他锁的问题,

mysql共享锁和排他锁详解

mysql共享锁和排他锁详解

此时共享查询处于阻塞,等待排它锁的释放,但是用普通查询能查到数据,因为没用上锁机制不与排他锁互斥,但查到的数据是修改数据之前的老数据。

mysql共享锁和排他锁详解

然后我们提交数据,释放排他锁看下修改后的数据,此时可用排他查,共享查和普通查询, 因为事务提交后该行数据释放排他锁,下面就只显示普通查询,其他的同学们自己去验证。

mysql共享锁和排他锁详解

mysql共享锁和排他锁详解

可以看到结果与预期的一样。

设置共享锁:SELECT ... LOCK IN SHARE MODE;
设置排他锁:SELECT ... FOR UPDATE;

  • 对于select 语句,innodb不会加任何锁,也就是可以多个并发去进行select的操作,不会有任何的锁冲突,因为根本没有锁。

  • 对于insert,update,delete操作,innodb会自动给涉及到的数据加排他锁,只有查询select需要我们手动设置排他锁。


来源:

http://www.cnblogs.com/boblogsbo/p/5602122.html

http://www.jianshu.com/p/88231c4944f7


分享到:
0 0

*有问题之处烦请在评论中指出非常感谢!
不是我想要的内容,继续搜索:

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
mysql 为什么添加索引可以提高访问速度   阅读:4922centos 7 设置 nginx-1.11.10 开机启动   阅读:6750php打印三角形   阅读:5742php连接redis   阅读:4527mysql共享锁和排他锁详解   阅读:5798把php session 会话保存到redis   阅读:5907php连接redis   阅读:4527linux php7安装yaf扩展   阅读:6504nginx安装redis模块   阅读:2725mongodb设置shell开机启动脚本   阅读:7473mysql数据库性能的基本优化   阅读:3745小米手机端商城rem适配原理   阅读:5792php 统计网页打开耗时和脚本运行内存   阅读:5525网站局部小图片优化-base64编码图片   阅读:7252centos7开启交换内存   阅读:8637栈和堆的区别   阅读:3973什么是天使轮?什么是A轮融资?B轮融资?   阅读:3242十张GIF让你弄懂递归等概念   阅读:4907nginx安装redis模块   阅读:2725移动端js触摸touch详解(附带案例源码)   阅读:13359用php从1乘到100的值   阅读:5203centos 7 添加 redis 3.2.9 开机启动脚本   阅读:7781mysql5.7开启sql日志的配置   阅读:7021企业让你去面试,可能不是真的招人   阅读:4885centos 7 添加 redis 3.2.9 开机启动脚本   阅读:7781php 获取当前前后年、月、星期、日、时分秒的时间   阅读:5149php文件下载防盗链   阅读:8157面试的时候回去等通知,等电话的真实意思   阅读:18987简单的DOS攻击之死亡之ping详解   阅读:36220PHP 鸟哥:我也曾经是“不适合”编程的人   阅读:10697企业让你去面试,可能不是真的招人   阅读:4885封装php redis缓存操作类   阅读:7084php swoole搭建简单的聊天室   阅读:1731mongodb设置shell开机启动脚本   阅读:7473linux php7安装yaf扩展   阅读:6504centos 7 安装 nginx-1.11.10   阅读:6802比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:4123shell脚本批量删除几天前的文件   阅读:7382php生成二维码   阅读:4471企业让你去面试,可能不是真的招人   阅读:4885一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:109600纯干货,程序员面试的超实用技巧   阅读:3372centos 7 开启网络   阅读:4870网站性能优化-页面静态缓存   阅读:4595web项目高并发量网站解决方案   阅读:3661关于PHP程序员技术职业生涯规划   阅读:1712php中地址引用&的真正理解-变量引用、函数引用、对象引用   阅读:4533霍金24岁博士毕业论文在线预览   阅读:4495mysql5.7主从同步中binlog同步模式详解   阅读:3993linux php7安装yaf扩展   阅读:6504