个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~
⑩⑦【MySQL】锁:全局锁、表级锁、行级锁
1. 锁
锁
:
- 锁是什么?
- 锁是计算机协调多个进程或线程并发访问某一资源的机制 。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性 是所有数据库必须解决的一个问题,锁冲突 也是影响数据库并发访问性能的一个重要因素。从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。
锁的分类
:
- MySQL中的锁,按照锁的粒度分,可分为下述三类:
-
- ①
全局锁
:锁定数据库中所有的表。 - ②
表级锁
:每次操作锁住整张表。 - ③
行级锁
:每次操作锁住对应的行数据。
- ①
2. 全局锁
全局锁
:
- 全局锁就是对整个数据库实例加锁 ,加锁后整个实例就处于只读状态,后续的
DML
的写语句,DDL
语句,已经更新操作的事务提交语句都将被阻塞。其典型的使用场景是:做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性 。