如何理解mysql锁机制


本文摘自PHP中文网,作者V,侵删。

MySQL锁的概述

相对于其它数据库而言,MySQL的锁机制比较简单,其最 显著的特点是不同的存储引擎支持不同的锁机制。比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking)。BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁。InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。

表级锁:表级锁是MySQL中锁定粒度最大的一种锁,表示对当前操作的整张表加锁。它开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。

免费学习视频教程分享:mysql视频教程

行级锁:行级锁是MySQL中锁定粒度最细的一种锁,表示只针对当前操作的行进行加锁。开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。

页级锁:页级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多。行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁。开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

从上述特点可见,很难笼统地说哪种锁更好,只能就具体应用的特点来说哪种锁更合适!!仅从锁的角度 来说:表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用。而行级锁则更适合于有大量按索引条件并发更新少量不同数据,同时又有 并发查询的应用,如一些在线事务处理(OLTP)系统。

举例说明

1、在购买商品时,商品库存只有1个的时候,两个人同时购买的时候,到底是谁买到的问题。

2、会用到事务,先从库存表中取出物品的数据,然后插入订单,付款后,插入付款表信息。

3、更新商品的数量,在这个过程中,使用锁可以对有限的资源进行保护,解决隔离和并发的矛盾。

锁的分类

按操作分:

读锁(共享锁):针对同一份数据,多个读取操作可以同时进行而不互相影响。

写锁(排它锁):当前写操作没有完成前,会阻断其他写锁和读锁。

按粒度分:

表锁、行锁、页锁

相关文章教程推荐:mysql教程

以上就是如何理解mysql锁机制的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql如何设置单表大小

mysql示例dtid主从原理解

如何查询mysql中的所有用户

mysql中jdbc如何实现自动重连机制的实例

mysql select 语句的基本用法

mysql 幻读怎么解决?

mysql中如何统计数据?

mysql中删除语句怎么写

一文读懂navicat for mysql基础知识

mysql数据库忘记密码时如何修改?

更多相关阅读请进入《理解》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...