mysql以表级锁,mysql 表级锁

表级锁:分为读锁和写锁:

lock tables table_name read;//其他事务只能读,不能加写锁,要等待更新。

SESSION 50 执行:

mysql> update test set name='ccc' where id=1;

mysql> show full processlist;

+----+---------+----------------------+--------+---------+------+------------------------------+---------------------------------------+

| Id | User | Host | db | Command | Time | State | Info |

+----+---------+----------------------+--------+---------+------+------------------------------+---------------------------------------+

| 20 | monitor | 115.236.160.82:56186 | NULL | Sleep | 162 | | NULL |

| 21 | monitor | 115.236.160.82:56187 | NULL | Sleep | 162 | | NULL |

| 23 | monitor | 115.236.160.82:56208 | NULL | Sleep | 43 | | NULL |

| 24 | monitor | 115.236.160.82:56209 | NULL | Sleep | 43 | | NULL |

| 47 | monitor | 115.236.160.82:54858 | NULL | Sleep | 66 | | NULL |

| 48 | monitor | 115.236.160.82:54859 | NULL | Sleep | 67 | | NULL |

| 49 | root | localhost | DEVOPS | Query | 0 | init | show full processlist |

| 50 | root | localhost | DEVOPS | Query | 27 | Waiting for table level lock | update test set name='ccc' where id=1 |

+----+---------+----------------------+--------+---------+------+------------------------------+---------------------------------------+

8 rows in set (0.00 sec)

lock tables table_name write;//其他事务不能读

解锁:

unlock tables;

---------------------------------------------

行级锁:行锁是对索引加锁

目前对于表级锁查找持有的thread id 没有好的办法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值