MySQL_S锁_X锁_read lock_write lock

MySQL_S锁_X锁_read lock_write lockmysql

 

共享锁和排它锁

MySQL的锁系统:shared lock和exclusive lock(共享锁和排他锁,也叫读锁和写锁,即read lock和write lock)sql

读锁是共享的,或者说是相互不阻塞的数据库

写锁是排他的,一个写锁会阻塞其余的写锁和读锁并发

在实际的数据库系统中,每时每刻都发生锁定,当某个用户在修改某部分数据时,mysql会经过锁定阻止其余用户对同一数据的读取spa

 

共享锁【S锁】

又称读锁,若事务T对数据对象A加上S锁,则事务T能够读A但不能修改A,其余事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。对象

这保证了其余事务能够读A,但在T释放A上的S锁以前不能对A作任何修改。事务

 

排他锁【X锁】

又称写锁。若事务T对数据对象A加上X锁,事务T能够读A也能够修改A,其余事务不能再对A加任何锁,直到T释放A上的锁。it

这保证了其余事务在T释放A上的锁以前不能再读取和修改A。table

 

锁的粒度和锁的策略

MySQL有三种锁的级别:页级、表级、行级。数据

MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认状况下是采用行级锁。

MySQL这3种锁的特性可大体概括以下:

表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的几率最高,并发度最低。

行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的几率最低,并发度也最高。

页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度通常。

================END================

相关文章
相关标签/搜索