位置: 编程技术 - 正文

MySQL中的行级锁、表级锁、页级锁(mysql行锁的作用)

编辑:rootadmin

推荐整理分享MySQL中的行级锁、表级锁、页级锁(mysql行锁的作用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql的行级锁和表级锁,mysql的行级锁加在哪个位置,mysql的行级锁和表级锁,mysql的行级锁和表级锁,mysql的行级锁加在哪个位置,mysql行级锁实现原理,mysql 行级锁,mysql的行级锁加在哪个位置,内容如对您有帮助,希望把文章链接给更多的朋友!

在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足。

在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引擎)、表级锁(MYISAM引擎)和页级锁(BDB引擎 )。

一、行级锁

行级锁是Mysql中锁定粒度最细的一种锁,表示只针对当前操作的行进行加锁。行级锁能大大减少数据库操作的冲突。其加锁粒度最小,但加锁的开销也最大。行级锁分为共享锁 和 排他锁。

特点

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

二、表级锁

表级锁是MySQL中锁定粒度最大的一种锁,表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分MySQL引擎支持。最常使用的MYISAM与INNODB都支持表级锁定。表级锁定分为表共享读锁(共享锁)与表独占写锁(排他锁)。

特点

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

三、页级锁

表级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁.表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁

特点

MySQL中的行级锁、表级锁、页级锁(mysql行锁的作用)

开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般

MySQL常用存储引擎的锁机制

MyISAM和MEMORY采用表级锁(table-level locking) BDB采用页面锁(page-level locking)或表级锁,默认为页面锁 InnoDB支持行级锁(row-level locking)和表级锁,默认为行级锁

四、Innodb中的行锁与表锁

前面提到过,在Innodb引擎中既支持行锁也支持表锁,那么什么时候会锁住整张表,什么时候或只锁住一行呢?

InnoDB行锁是通过给索引上的索引项加锁来实现的,这一点MySQL与Oracle不同,后者是通过在数据块中对相应数据行加锁来实现的。InnoDB这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁!

在实际应用中,要特别注意InnoDB行锁的这一特性,不然的话,可能导致大量的锁冲突,从而影响并发性能。

行级锁都是基于索引的,如果一条SQL语句用不到索引是不会使用行级锁的,会使用表级锁。行级锁的缺点是:由于需要请求大量的锁资源,所以速度慢,内存消耗大。

五、行级锁与死锁

MyISAM中是不会产生死锁的,因为MyISAM总是一次性获得所需的全部锁,要么全部满足,要么全部等待。而在InnoDB中,锁是逐步获得的,就造成了死锁的可能。

在MySQL中,行级锁并不是直接锁记录,而是锁索引。索引分为主键索引和非主键索引两种,如果一条sql语句操作了主键索引,MySQL就会锁定这条主键索引;如果一条语句操作了非主键索引,MySQL会先锁定该非主键索引,再锁定相关的主键索引。 在UPDATE、DELETE操作时,MySQL不仅锁定WHERE条件扫描过的所有索引记录,而且会锁定相邻的键值,即所谓的next-key locking。

当两个事务同时执行,一个锁住了逐渐索引在等待其他相关索引,一个锁定了非主键索引,在等待主键索引。这样就会发生死锁。

发生死锁后,InnoDB一般都可以检测到,并使一个事务释放锁回退,另一个获取锁完成事务。

有多种方法可以避免死锁,这里只介绍常见的三种,具体如下

1、如果不同程序会并发存取多个表,尽量约定以相同的顺序访问表,可以大大降低死锁机会。

2、在同一个事务中,尽可能做到一次锁定所需要的所有资源,减少死锁产生概率;

3、对于非常容易产生死锁的业务部分,可以尝试使用升级锁定颗粒度,通过表级锁定来减少死锁产生的概率;

标签: mysql行锁的作用

本文链接地址:https://www.jiuchutong.com/biancheng/312475.html 转载请保留说明!

上一篇:Mysql半同步复制原理及问题排查

下一篇:MySQL数据库三种常用存储引擎特性对比(mysql数据库三种复制类型)

  • 小规模企业所得税多少
  • 报考中级会计师怎么报名
  • 建筑服务预征缴纳税款包括附加税吗
  • 个别计价法和先进先出法举例
  • 固定资产报废电脑
  • 刚成立的公司好不好
  • 小规模纳税人变成一般纳税人之前的发票变更
  • 股息红利增值税和企业所得税
  • 买车支付的车辆购置税怎么入账
  • 遗失的支票怎样避免经济损失
  • 支付一年房租计入什么科目
  • 税控设备全额抵扣政策
  • 购置税交了发票能作废吗
  • 工程款转账一般要多久
  • 年终结账后,应当更换新账的有( )
  • 开具发票只有票号可以吗?
  • 税控盘怎么作废发票重新开
  • 增值税专用发票有效期是多长时间
  • 不能抵扣的进项税怎么做账
  • 退税记录显示税务审核中
  • 其他应收款如何调平分录
  • 小微企业怎么合法避税
  • 分配现金股利是什么活动
  • 逾期往来账款怎么处理?
  • 工程税金计入哪个账户
  • 培训费和差旅费可以一起报嘛
  • 政策性搬迁的会计实用报告
  • 预缴增值税的情况四种情形汇总表怎么填
  • 斐讯p.to路由器管理员密码
  • 如何批量更改多个excel内容
  • 开机反应慢是怎么回事
  • 借别人资质投标如何签合同
  • php 数组定义
  • PHP:imagefilledpolygon()的用法_GD库图像处理函数
  • 融资性售后回租和融资租赁的区别
  • crontab不执行的原因和解决方案
  • 职工工资扣税比例
  • php怎么访问本地的网页
  • YOLOv8(n/s/m/l/x)&YOLOv7(yolov7-tiny/yolov7/yolov7x)&YOLOv5(n/s/m/l/x)不同模型参数/性能对比(含训练及推理速度)
  • 怎么用ai做vi
  • 管理费用未分配利润
  • 异地项目需要预缴增值税吗
  • 销售旧货和销售使用过的固定资产
  • 发票没有填写开户行,可以报销吗
  • 尚未抄税无法申报
  • 给员工分红是否交税
  • mongodb的坑
  • 销售不动产统一发票英文翻译
  • 小规模纳税人是个体户吗
  • 合伙企业可以列入法人吗
  • 收员工伙食费会计分录
  • 交付使用资产是固定资产吗
  • 增值税加计抵减是什么意思
  • 项目对公司的战略意义
  • 招标代理服务费取费标准
  • 以前年度损益调整结转到哪里
  • 加计抵减期末有余额怎么办
  • 哪些业务需要计提国别风险准备金
  • 收到红字发票怎么做账怎么做进项税额转出
  • 利润率百分百是什么意思
  • 投资者以现金支出为准
  • 发票作废才能验旧吗
  • 公司向股东借款多久必须归还
  • 苗木免税发票可以开专票吗
  • 成本会计工作主要内容
  • mysql常见故障和解决方法
  • windows8禁用uac
  • macbook如何使用word
  • win8系统如何关闭杀毒系统
  • vmware虚拟机Linux扩展硬盘
  • OfcPfwSvc.exe - OfcPfwSvc是什么进程 有什么用
  • win10系统安装搜狗输入法很慢
  • linux中xargs的含义
  • unity3d 帧同步
  • shell的实现
  • 获取已安装应用列表的权限在哪里设置
  • js写日期
  • jquery技巧
  • 朝阳区第六税务所
  • 如何查公司税务问题
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设