Mysql 锁总结
2024-08-30 15:51:39
锁
部分总结参考博客
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 |
+------+
最新文章
- [bigdata] hadoop 参数配置解析
- PRML 术语
- 安装完最小化 RHEL/CentOS 7 后需要做的 30 件事情(四)码农网
- (C++)String的用法
- VS2015中的异常配置
- APKTool用法
- Dotliquid使用Json模板变量
- java finally深入探究
- Python3.6.1的安装
- 在Service中抛出异常事务未回滚问题分析与解决
- 升级:DNAtools for Excel工具箱,2.x英文版- VBA代码破解工具
- FJUTOJ-周赛2016-12-16
- 《JAVA并发编程实战》示例程序 第三章
- Ocelot简易教程(四)之请求聚合以及服务发现
- SpringCloud Feign
- error: 'Can't connect to local MySQL server through socket '/data/3307/data/mysql.sock' (2)'
- 自然语言处理的CNN模型中几种常见的池化方法
- springboot 解决配置js/css/img缓存问题
- CP-ABE ToolKit 安装笔记(转载)
- Zabbix应用六:Zabbix监控Redis
热门文章
- update cdh version ,but cdh use old conf ,problem solve
- iOS音频与视频的开发(二)- 使用AVAudioRecorder进行录制音频
- 易爆物(X-Plosives )基础并查集
- hdu6195	 cable cable cable(from 2017 ACM/ICPC Asia Regional Shenyang Online)
- 2017年“嘉杰信息杯” 中国大学生程序设计竞赛全国邀请赛 Highway
- Collection2
- 1536 不一样的猜数游戏 dp思维 + 找规律
- idea安装mybatis插件
- AJPFX关于StringBuffer,StringBuilder类总结(二)
- Android 仿百度医生的智能分诊界面