For investors
股价:
5.36 美元 %For investors
股价:
5.36 美元 %认真做教育 专心促就业
锁的应用能够让线程的安全性得到很大的提高,而本文我们就通过案例分析来简单了解一下,MySQL数据库锁的类型与特点分析。
行级锁和表级锁及页级锁
在MySQL数据库体系中,可以按照锁的粒度把数据库锁分为行级锁(Innodb引擎)、表级锁(MyISam引擎)和页级锁(BDB引擎)。
行级锁
行级锁是MySQL中锁定粒度细的一种锁,表示只针对当前操作的行进行加锁。
行级锁能大大减少数据库操作的冲突。
其加锁粒度小,但加锁的开销也大。
行级锁分为共享锁和排他锁。具体针对于这两种锁会在后续介绍。
特点
开销大,加锁慢;
会出现死锁;
锁定粒度小,发生锁冲突的概率低,并发度也高。
表级锁
表级锁是MySQL中锁定粒度大的一种锁,表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分MySQL引擎支持。
常使用的MYISAM与INNODB都支持表级锁定。
表级锁定分为表共享读锁(共享锁)与表独占写锁(排他锁)。
特点
开销小,加锁快;
不会出现死锁;
锁定粒度大,发出锁冲突的概率高,并发度低。
页级锁
页级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁。
表级锁速度快,但冲突多,行级冲突少,但速度慢。
所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁
特点
开销和加锁时间界于表锁和行锁之间;
会出现死锁;
锁定粒度界于表锁和行锁之间,并发度一般
【免责声明】:本内容转载于网络,转载目的在于传递信息。文章内容为作者个人意见,本平台对文中陈述、观点保持中立,不对所包含内容的准确性、可靠性与完整性提供形式地保证。请读者仅作参考。更多内容请加danei0707学习了解。欢迎关注“达内在线”参与分销,赚更多好礼。