MySQL行级锁、表级锁、页级锁详细介绍

2023-11-14

页级:引擎 BDB。
表级:引擎 MyISAM , 理解为锁住整个表,可以同时读,写不行
行级:引擎 INNODB , 单独的一行记录加锁

表级,直接锁定整张表,在你锁定期间,其它进程无法对该表进行写操作。如果你是写锁,则其它进程则读也不允许
行级,,仅对指定的记录进行加锁,这样其它进程还是可以对同一个表中的其它记录进行操作。
页级,表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。

MySQL 5.1支持对MyISAM和MEMORY表进行表级锁定,对BDB表进行页级锁定,对InnoDB表进行行级锁定。
对WRITE,MySQL使用的表锁定方法原理如下:
如果在表上没有锁,在它上面放一个写锁。
否则,把锁定请求放在写锁定队列中。

对READ,MySQL使用的锁定方法原理如下:
如果在表上没有写锁定,把一个读锁定放在它上面   
否则,把锁请求放在读锁定队列中。

InnoDB使用行锁定,BDB使用页锁定。对于这两种存储引擎,都可能存在死锁。这是因为,在SQL语句处理期间,InnoDB自动获得行锁定和BDB获得页锁定,而不是在事务启动时获得。

行级锁定的优点:
·         当在许多线程中访问不同的行时只存在少量锁定冲突。
·         回滚时只有少量的更改。
·         可以长时间锁定单一的行。

行级锁定的缺点:
·         比页级或表级锁定占用更多的内存。
·         当在表的大部分中使用时,比页级或表级锁定速度慢,因为你必须获取更多的锁。
·         如果你在大部分数据上经常进行GROUP BY操作或者必须经常扫描整个表,比其它锁定明显慢很多。
·         用高级别锁定,通过支持不同的类型锁定,你也可以很容易地调节应用程序,因为其锁成本小于行级锁定。

在以下情况下,表锁定优先于页级或行级锁定:
·         表的大部分语句用于读取。
·         对严格的关键字进行读取和更新,你可以更新或删除可以用单一的读取的关键字来提取的一行:
·                UPDATE tbl_name SET column=value WHERE unique_key_col=key_value;
·                DELETE FROM tbl_name WHERE unique_key_col=key_value;
·         SELECT 结合并行的INSERT语句,并且只有很少的UPDATE或DELETE语句。
·         在整个表上有许多扫描或GROUP BY操作,没有任何写操作。

/* ========================= mysql 锁表类型和解锁语句 ========================= */

如果想要在一个表上做大量的 INSERT 和 SELECT 操作,但是并行的插入却不可能时,可以将记录插入到临时表中,然后定期将临时表中的数据更新到实际的表里。可以用以下命令实现:

代码如下:

mysql> LOCK TABLES real_table WRITE, insert_table WRITE;
mysql> INSERT INTO real_table SELECT * FROM insert_table;
mysql> TRUNCATE TABLE insert_table;
mysql> UNLOCK TABLES;

上述三种锁的特性可大致归纳如下:
1) 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
2) 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
3) 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

   三种锁各有各的特点,若仅从锁的角度来说,表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如WEB应用;行级锁更适合于有大量按索引条件并发更新少量不同数据,同时又有并发查询的应用,如一些在线事务处理(OLTP)系统。

MySQL表级锁有两种模式:表共享读锁(Table Read Lock)和表独占写锁(Table Write Lock)。什么意思呢,就是说对MyISAM表进行读操作时,它不会阻塞其他用户对同一表的读请求,但会阻塞 对同一表的写操作;而对MyISAM表的写操作,则会阻塞其他用户对同一表的读和写操作。

  MyISAM表的读和写是串行的,即在进行读操作时不能进行写操作,反之也是一样。但在一定条件下MyISAM表也支持查询和插入的操作的并发进行,其机 制是通过控制一个系统变量(concurrent_insert)来进行的,当其值设置为0时,不允许并发插入;当其值设置为1 时,如果MyISAM表中没有空洞(即表中没有被删除的行),MyISAM允许在一个进程读表的同时,另一个进程从表尾插入记录;当其值设置为2时,无论 MyISAM表中有没有空洞,都允许在表尾并发插入记录。

     MyISAM锁调度是如何实现的呢,这也是一个很关键的问题。例如,当一个进程请求某个MyISAM表的读锁,同时另一个进程也请求同一表的写锁,此时 MySQL将会如优先处理进程呢?通过研究表明,写进程将先获得锁(即使读请求先到锁等待队列)。但这也造成一个很大的缺陷,即大量的写操作会造成查询操 作很难获得读锁,从而可能造成永远阻塞。所幸我们可以通过一些设置来调节MyISAM的调度行为。我们可通过指定参数low-priority- updates,使MyISAM默认引擎给予读请求以优先的权利,设置其值为1(set low_priority_updates=1),使优先级降低。

  InnoDB锁与MyISAM锁的最大不同在于:一是支持事务(TRANCSACTION),二是采用了行级锁。我们知道事务是由一组SQL语句组成的逻辑处理单元,其有四个属性(简称ACID属性),分别为:

原子性(Atomicity):事务是一个原子操作单元,其对数据的修改,要么全部执行,要么全都不执行;
一致性(Consistent):在事务开始和完成时,数据都必须保持一致状态;
隔离性(Isolation):数据库系统提供一定的隔离机制,保证事务在不受外部并发操作影响的“独立”环境执行;
持久性(Durable):事务完成之后,它对于数据的修改是永久性的,即使出现系统故障也能够保持。

nnoDB有两种模式的行锁:

1)共享锁:允许一个事务去读一行,阻止其他事务获得相同数据集的排他锁。
    ( Select * from table_name where ......lock in share mode)

2)排他锁:允许获得排他锁的事务更新数据,阻止其他事务取得相同数据集的共享读锁和  排他写锁。(select * from table_name where.....for update)
    为了允许行锁和表锁共存,实现多粒度锁机制;同时还有两种内部使用的意向锁(都是表锁),分别为意向共享锁和意向排他锁。
    InnoDB行锁是通过给索引项加锁来实现的,即只有通过索引条件检索数据,InnoDB才使用行级锁,否则将使用表锁!

另外:插入,更新性能优化的几个重要参数

bulk_insert_buffer_size
批量插入缓存大小, 这个参数是针对MyISAM存储引擎来说的.适用于在一次性插入100-1000+条记录时, 提高效率.默认值是8M.可以针对数据量的大小,翻倍增加.

concurrent_insert
并发插入, 当表没有空洞(删除过记录), 在某进程获取读锁的情况下,其他进程可以在表尾部进行插入.

值可以设0不允许并发插入, 1当表没有空洞时, 执行并发插入, 2不管是否有空洞都执行并发插入.
默认是1 针对表的删除频率来设置.

delay_key_write
针对MyISAM存储引擎,延迟更新索引.意思是说,update记录时,先将数据up到磁盘,但不up索引,将索引存在内存里,当表关闭时,将内存索引,写到磁盘. 值为 0不开启, 1开启. 默认开启.

delayed_insert_limit, delayed_insert_timeout, delayed_queue_size
延迟插入, 将数据先交给内存队列, 然后慢慢地插入.但是这些配置,不是所有的存储引擎都支持, 目前来看, 常用的InnoDB不支持, MyISAM支持. 根据实际情况调大, 一般默认够用了

转载于:https://www.cnblogs.com/wxmarr/p/4551072.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL行级锁、表级锁、页级锁详细介绍 的相关文章

随机推荐

  • 数学图形之单叶双曲面

    双曲线绕其对称轴旋转而生成的曲面即为双曲面 在数学里 双曲面是一种二次曲面 其中单叶双曲面可以用公式表达为 x 2 a 2 y 2 b 2 z 2 c 2 1 在现实中 许多发电厂的冷却塔结构是单叶双曲面形状 由于单叶双曲面是一种双重直纹曲
  • java web——servlet+jsp实现前后台交互

    大学生涯终于结束 在公司学习了一段时间的java web方面的知识 结合自己之前的一些理解 想通过几篇文章来对我所接触到的java技术进行梳理与总结 也希望能给大家一些参考 由于作者水平有限 难免存在一些不足之处 希望能一起探讨 1 ser
  • 解决pip._vendor.urllib3.exceptions.ReadTimeoutError: HTTPSConnectionPool

    解决pip vendor urllib3 exceptions ReadTimeoutError HTTPSConnectionPool host files pythonhosted org port 443 Read timed out
  • MySQL JSON数据类型

    一 JSON数据类型 JSON JavaScript Object Notation 主要用于互联网应用服务之间的数据交换 MySQL 支持JSON 对象和JSON 数组两种类型 JSON 类型是从 MySQL 5 7 版本开始支持的功能
  • Flutter点击事件实现

    GestureDetector 1 创建自定义button类 2 在其中使用GestureDetector并复写onTap回调 参考 https flutter io cookbook gestures handling taps impo
  • 家族企业的优势、劣势分析

    家族企业优势 1 创业时期 凭借家族成员之间特有的血缘关系 类似血缘关系 亲缘关系和相关的社会网络资源 以较低的成本迅速集聚人才 全情投入 团结奋斗 甚至可以不计报酬 能够在很短的一个时期内获得竞争优势 较快的完成原始资本的积累 2 反应迅
  • 对大数据的理解

    大数据几个不同的定义 James Kobielus 大数据事实上是引用极限可扩展分析的概念 极限可扩展分析 这个词在我看来是人们所说大数据的核心 在某种程度上 是可以用三个V来概括的 Volume 数据量 可以使TB可以是PB甚至更大 Ve
  • 漏洞扫描工具AWVS介绍及安装教程

    1 AWVS简介 AWVS Acunetix Web Vulnerability Scanner 是一款知名的网络漏洞扫描工具 通过网络爬虫测试网站安全 检测流行的Web应用攻击 如跨站脚本 sql 注入等 据统计 75 的互联网攻击目标是
  • 如何破解Studio 3T (MongoDB可视化工具)

    首先新建一个记事本 写入如下内容 echo off ECHO 重置Studio 3T的使用日期 FOR f tokens 1 2 i IN reg query HKEY CURRENT USER Software JavaSoft Pref
  • MOS管漏电流产生的原因

    功耗是由漏电流引起的 尤其是在较低阈值电压下 了解MOS晶体管漏电流的六种不同原因 1 反向偏置pn结泄漏电流 在晶体管操作期间 MOS晶体管的漏极 源极和衬底结被反向偏置 因此 器件的漏电流被反向偏置 这种漏电流可能是由反向偏置区域中的少
  • windows自带磁盘修复命令chkdsk的使用方法

    在电脑使用过程会因突然断电或者是非正常关机等原因导致磁盘受损 这里介绍Windows系统自带chkdsk命令修复硬盘 2022 10 26补充 专业硬盘维修的朋友告诉我此命令不要随意使用 尤其硬盘已经有坏道 用该方法可能导致更严重的问题 大
  • python数据抓取中空格的影响

    在python数据抓取中 多一个空格或少一个空格 中间的差异的很大的 抓取一个网站 在定位后 只抓取前五行 无意中多了一个空格 数据一直不能正常显示 经过调试后 将空格去掉 定位的数据正常显示 如下
  • Matplotlib基本参数设置

    文章目录 Matplotlib基本参数设置 1 添加图标题 坐标轴标题 图例 2 添加坐标轴范围 画布网格 3 添加图形标注 4 改变横坐标和纵坐标上的刻度 ticks 5 中文支持相关设置 6 定义图形样式 Matplotlib基本参数设
  • python3集成matplotlib画图中文乱码的解决方法

    问题描述 在python中使用matplotlib画图 里面的中文会显示乱码方块 解决方法前提依赖 这是由于matplotlib默认使用的字体中不包含中文字符引起的 可以通过将中文字符加入到默认字体中解决 前提 查找本地都有哪些中文字体 打
  • 利用机器学习进行恶意代码分类

    原文链接 http drops wooyun org tips 8151 最近在Kaggle上微软发起了一个恶意代码分类的比赛 并提供了超过500G的数据 解压后 有意思的是 取得第一名的队伍三个人都不是搞安全出身的 所采用的方法与我们常见
  • IOC与DI总结

    编写流程 基于XML 导入jar包 4 1 gt beans core context expression commons logging 编写目标类 dao和service spring配置文件 IoC
  • Flutter获取屏幕及设备信息

    获取状态栏高度 import dart ui MediaQueryData fromWindow window padding top MediaQuery of context padding top 获取系统默认的AppBar等高度 位
  • web前端技术练习题

    选择题 1 以下哪个不属于Web前端开发的核心技术 A HTML C JavaScript B CSS D Java 2 关于HTML说法错误的是 A HTML标签的嵌套结构可以描述成一个网状结构 B 在 title 和 title 标签之
  • C语言字符型数据(一)—简单的恺撒密码

    首先声明 这些内容主要是面向C语言的初学者 尤其是正在学习C语言的学生 学习C语言的字符型数据时 首先需要记住两条重要特性 1 字符型数据存储的是字符的ASCII码值 2 由于ASCII码值本质上是一个整数 因此字符型数据可以像整数一样做加
  • MySQL行级锁、表级锁、页级锁详细介绍

    页级 引擎 BDB 表级 引擎 MyISAM 理解为锁住整个表 可以同时读 写不行行级 引擎 INNODB 单独的一行记录加锁 表级 直接锁定整张表 在你锁定期间 其它进程无法对该表进行写操作 如果你是写锁 则其它进程则读也不允许行级 仅对