Mysql 锁总结
锁

部分总结参考博客
http://b.codejs.cc/articles/2017/10/23/1508749325215.html
http://blog.csdn.net/cug_jiang126com/article/details/50544728
MyISAM 只支持表锁
show create table crm_member; ##查看引擎
alter table crm_member engine = MyISAM; ##更改表引擎
读锁演示
Session 1 读锁 其它session可以读不可写
lock table crm_member read;
Session 1 锁等待时间设置
select @@global.lock_wait_timeout; ##查看锁等待时间设置
set @@global.lock_wait_timeout = 20; ##设置锁等待时间为20秒
Session 2 查询数据 不影响
MariaDB [member]> select name from crm_member where id = 4;
+------+
| name |
+------+
| 222 |
+------+
1 row in set (0.00 sec)
Session 2 更新数据
MariaDB [member]>
MariaDB [member]> update crm_member set name = '222' where id = 4;
## 进入锁等待
Session 1 查看进程
show processlist;
| 97 | root | localhost | member | Query | 120 | Waiting for table level lock | update crm_member set name = '222' where id = 4 | 0.000 |
## 等待一个表级别的锁
Session 1 释放锁
MariaDB [member]> unlock tables;
Query OK, 0 rows affected (0.00 sec)
Session 2 获得锁 立即更新数据
MariaDB [member]> update crm_member set name = '222' where id = 4;
Query OK, 0 rows affected (3 min 9.38 sec)
Rows matched: 1 Changed: 0 Warnings: 0
Session 2 锁等待超时
MariaDB [member]> update crm_member set name = '222' where id = 4;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
写锁演示
Session 1 添加写锁
MariaDB [member]> lock table crm_member write;
Query OK, 0 rows affected (0.00 sec)
Session 1 添加写锁
MariaDB [member]> lock table crm_member write;
Query OK, 0 rows affected (0.00 sec)
Session 2 读数据
MariaDB [member]> select name from crm_member where id = 4;
Session 1 查看进程
MariaDB [member]> show processlist;
| 109 | root | localhost | member | Query | 2 | Waiting for table metadata lock | select name from crm_member where id = 4 | 0.000 |
## 等待一个元数据的锁
Session 2 读数据 锁等待超时
MariaDB [member]> select name from crm_member where id = 4;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
InnoDB 锁 既支持表锁(与MyISAM相同) 也支持 行锁。
排它锁演示
方式1 Session 1 直接update 其它session不可以读不可写 除非快照读
MariaDB [member]> begin;
Query OK, 0 rows affected (0.00 sec)
MariaDB [member]> update crm_member set name = 'aaaaaa' where id = 4;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
方式2 Session 1 for-update 其它session不可以读不可写 除非快照读
MariaDB [member]> begin;
Query OK, 0 rows affected (0.00 sec)
MariaDB [member]> select name from crm_member where id = 4 for update;
Session 2 方式1 事务方式 开始更新操作相同的记录
MariaDB [member]> begin;
Query OK, 0 rows affected (0.00 sec)
MariaDB [member]> update crm_member set name = 'bbb' where id = 4;
## 进入锁等待
Session 2 方式2 普通更新操作
MariaDB [member]> update crm_member set name = 'bbb' where id = 4;
Session 1 查看进程
MariaDB [member]> show processlist;
+-----+------+---------------------+--------+---------+-------+----------+-------------------------------------------------+----------+
| Id | User | Host | db | Command | Time | State | Info | Progress |
+-----+------+---------------------+--------+---------+-------+----------+-------------------------------------------------+----------+
| 109 | root | localhost | member | Query | 2 | updating | update crm_member set name = 'ccc' where id = 4 | 0.000 |
+-----+------+---------------------+--------+---------+-------+----------+-------------------------------------------------+----------+
## 有一个更新等待
Session 2 锁等待超时
MariaDB [member]> update crm_member set name = 'bbb' where id = 4;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
Session 1 查看数据 已经更改
MariaDB [member]> select name from crm_member where id = 4;
+------+
| name |
+------+
| ccc |
+------+
Session 2 读取到的数据没有更改 只能读取未提交版本的数据
MariaDB [member]> select name from crm_member where id = 4;
+------+
| name |
+------+
| bbb |
+------+
Mysql 锁总结的更多相关文章
- mysql锁
锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源(如CPU.RAM.I/O等)的争用以外,数据也是一种供许多用户共享的资源.如何保证数据并发访问的一致性.有效性是所有数 ...
- Mysql锁初步
存储引擎 要了解mysql的锁,就要先从存储引擎说起. 常用存储引擎列表如下图所示: 最常使用的两种存储引擎: Myisam是Mysql的默认存储引擎.当create创建新表时,未指定新表的存储引擎时 ...
- mysql锁表机制及相关优化
(该文章为方便自己查阅,也希望对大家有所帮助,转载于互联网) 1. 锁机制 当前MySQL支持 ISAM, MyISAM, MEMORY (HEAP) 类型表的表级锁,BDB 表支持页级锁,InnoD ...
- MySQL锁系列3 MDL锁
http://www.cnblogs.com/xpchild/p/3790139.html MySQL为了保护数据字典元数据,使用了metadata lock,即MDL锁,保证在并发的情况下,结构 ...
- 01 MySQL锁概述
锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源(如CPU.RAM.I/O 等)的争用以外,数据也是一种供许多用户共享的资源.如何保证数据并发访问的一致性.有效性是所有 ...
- Mysql锁机制介绍
Mysql锁机制介绍 一.概况MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制.比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking ...
- MySQL锁等待分析【2】
MySQL锁等待分析[1]中对锁等待的分析是一步一步来的.虽然最后是分析出来了,可是用时是比较长的:理清各个表之间的关系后,得到如下SQL语句,方便以后使用 select block_trx.trx_ ...
- MySQL锁与MVCC
--MySQL锁与MVCC --------------------2014/06/29 myisam表锁比较简单,这里主要讨论一下innodb的锁相关问题. innodb相比oracle锁机制简单许 ...
- MySQL锁总结
本文同时发表在https://github.com/zhangyachen/zhangyachen.github.io/issues/78 MySQL 锁基础 参考了何登成老师文章的结构MySQL 加 ...
- Mysql锁机制--并发事务带来的更新丢失问题
Mysql 系列文章主页 =============== 刚开始学习 Mysql 锁的时候,觉得 Mysql 使用的是行锁,再加上其默认的可重复读的隔离级别,那就应该能够自动解决并发事务更新的问题.可 ...
随机推荐
- Luogu P4889 kls与flag 【思维/排序】By cellur925
题目传送门 这题真的一点也不难qwq.只要想出来就没有什么代码难度的qwq. 每个竹竿只可能向左倒或向右倒,把这两种情况都存在数组中,将数组排序,就可以知道最后落在同一位置的有多少竹竿.就可以知道落在 ...
- 同一台服务器上部署多个Tomcat的配置修改方法
同一服务器部署多个tomcat时,存在端口号冲突的问题,所以需要修改tomcat配置文件server.xml,以tomcat7为例. 首先了解下tomcat的几个主要端口: <Server po ...
- nginx使用autoindex
有时候一个nginx服务就是为了用来下载文件的,网上很多下载服务都是这样的 这个很简单 在http段加上以下参数,重启nginx就行. autoindex on; autoindex_exact_si ...
- 关于BMP
关于BMP位图的资料网上有很多,内容也比较基础.本文实现BMP位图的读取.显示.保存,并对一些重要的问题进行说明(包括字节对齐.内存中的存储顺序.调色板). BMP文件共包括文件头.信息头.调色板(位 ...
- 142 Linked List Cycle II 环形链表 II
给一个链表,返回链表开始入环的第一个节点. 如果链表无环,则返回 null.说明:不应修改给定的链表.补充:你是否可以不用额外空间解决此题?详见:https://leetcode.com/proble ...
- RHEL7.2安装及配置实验环境
截图太多了,就不一一上传了,请查看这个分享网址 http://pan.baidu.com/s/1kVeYANH 什么时候博客更新下能直接把图一下复制进来多好!省事.
- windows 7 正确禁用 IPv6
与Windows XP和Windows Server 2003不同的是,Windows Vista和Windows Server 2008中的IPv6无法被卸载.然而,在Windows Vista和W ...
- 用私有构造器或者枚举类型强化Singleton
参考Effective Java第三版 Joshua J. Bloch 参与编写JDK的大佬,上次看Collections的源码时看见了他的名字,然后翻了翻书,竟然就是他写的! 1.常见的一种: pu ...
- BeanUtils.copyProperties(productInfo, productInfoVO);
一:spring的工具类方法:BeanUtils.copyProperties(orderMasterDTO, orderMasterDO); 作用:将orderMasterDTO对象中的属性值,赋值 ...
- ListView中含有EditText时候--要命的焦点问题迎刃而解
最近做项目的时候遇到了一个问题,就是在ListView的item上面含有一个EditText,要求是这样: 1当点击item的时候,item可以点击; 2当点击EditText的时候EditText也 ...