数据库锁机制为什么很重要?
前言
在座的朋友们,你们的时间够用吗?想要成为一个成功的人吗?如果你们都有这样的疑惑,那就保持一刻谦虚的心态,跟着罗老师学习时间管理吧!
毕竟时间管理大师是一个用户访问多个资源,今天咱们来讲讲当多个用户并发访问同一个资源时的情况
在数据库中,如果多个事务同时对一个数据进行操作,并发的操作若不加控制,可能会读取和存储不正确的数据,破坏数据库的一致性、脏读、不可重复读、幻读等、甚至可能产生死锁。
为了解决这个问题,加锁是一个非常重要的技术,对实现数据库并发控制是一个好的方案。
简单说,当一个执行 sql 语句的事务想要操作表记录之前,先向数据库发出请求,对你访问的记录加锁,在这个事务释放这个锁之前,其他事务不能对这些数据进行更新操作。
本文将基于 MySQL,介绍数据库锁机制,相信大家耐心看了之后肯定有收获,码字不易,别忘了「在看」,「转发」哦。
锁的类型
MyISAM 锁机制
InnoDB 锁机制
正文
01 锁的类型
从对数据的操作粒度来划分,MySQL 大致可归纳为 3 种锁。
表级锁
表级别的锁定是 MySQL 各存储引擎中最大颗粒度的锁定机制。该锁定机制最大的特点是实现逻辑非常简单,带来的系统负面影响最小。
所以获取锁和释放锁的速度很快。由于表级锁一次会将整个表锁定,所以可以很好的避免困扰我们的死锁问题。
当然,锁定颗粒度大所带来最大的负面影响就是出现锁定资源争用的概率也会最高,致使并发大度大打折扣。
行级锁
行级锁定最大的特点就是锁定对象的颗粒度很小,也是目前各大数据库管理软件所实现的锁定颗粒度最小的。
由于锁定颗粒度很小,所以发生锁定资源争用的概率也最小,能够给予应用程序尽可能大的并发处理能力而提高一些需要高并发应用系统的整体性能。
虽然能够在并发处理能力上面有较大的优势,但是行级锁定也因此带来了不少弊端。由于锁定资源的颗粒度很小,所以每次获取锁和释放锁需要做的事情也更多,带来的消耗自然也就更大了。此外,行级锁定也最容易发生死锁。
页级锁
页面锁会去锁定一页的数据,我们知道 MySQL 的索引本身是由 B+ 树实现的。
每个叶子节点的单位页,叶子节点上面存放了多个记录行,数据存储是按照一页一页来的,每次锁定一页的数据,其实就是相邻的数据,开销和加锁时间界于表锁和行锁之间。
页级锁也会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。
02 MyISAM锁机制
MyISAM引擎只提供表锁。
在执行查询语句( SELECT )前,会自动给涉及的表加读锁,此时允许其他用户对同一表的读操作。但会阻塞对同一个表的写操作。
在执行更新操作( UPDATE、DELETE、INSERT 等)前,会自动给涉及的表加写锁,此时会阻塞其他用户对同一个表的读操作和写操作。
03 InnoDB锁机制
InnoDB 支持表锁、行锁,实际上InnoDB 是通过给索引项加锁,来实现行锁的。
只有查询数据时,检索条件走索引才可以使用行级锁,否则 InnoDB 将使用表锁。
在实际开发中,要特别注意 InnoDB 这一特性,不然,可能造成大量的锁冲突,从而影响并发!!!
InnoDB使用索引的条件
(1)在不通过索引条件查询的时候,InnoDB 确实使用的是表锁,而不是行锁。
(2)行锁是针对索引加锁,不是针对记录加的锁。即使访问的是不同行,但如果它们索引相同,还是会出现锁冲突。
(3)当表中含有多个索引的时候,不同的事务可以使用不同的索引锁定不同的行。
(4)即使在条件中使用了索引,但是否使用索引来检索数据是由 MySQL 通过判断不同执行计划的代价决定的。如果 MySQL 认为全表扫描效率更高,比如很小的表,也不会使用索引,此时 InnoDB 将使用表锁,而不是行锁。因此,在分析锁冲突的时候,不要忘记检查 SQL 的执行计划,以确定是否真正使用了索引。
在默认的可重复读隔离级别下:
执行查询语句( SELECT )前,由于 MVCC(多版本控制)的方式,什么锁都不会加。
在执行更新操作( UPDATE、DELETE、INSERT 等)前,会自动给涉及的行加写锁,此时会阻塞其他用户的写操作,但是通过 MVCC(多版本控制)的方式允许读操作。
04 总结
通过这篇文章,基于MySQL,为大家介绍了数据库的锁机制。针对不同情况,什么时候使用锁,锁到底生不生效是大家需要关注的问题。
特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:长按订阅更多精彩▼如有收获,点个在看,诚挚感谢
数据库锁机制为什么很重要?相关推荐
- 带你了解什么是MySQL数据库(八)数据库锁机制
目录 数据库的锁机制 锁的分类 MySQL中的行级锁,表级锁,页级锁(粒度) 行级锁之共享锁与排他锁(级别) innodb存储引擎的锁机制 行级锁与表级锁区分 三种行锁算法 死锁问题 什么时候使用表锁 ...
- MySQL数据库读现象 数据库锁机制 Innodb存储引擎行级锁
数据库读现象 数据库管理软件的"读现象"指的是当多个事务并发执行时,在读取数据方面可能碰到的问题,包括有脏读.不可重复读和幻读. 创建数据表 # 创建数据表 create tabl ...
- SQL Server数据库锁机制及类型
SQL Server数据库锁机制及类型 [06-05 12:08:14]作者:责任编辑:heyaorong Microsoft SQL Server(以下简称SQL Server)作为一种中小型数据库 ...
- 传智播客JavaWeb day11--事务的概念、事务的ACID、数据库锁机制、
1. 什么叫做事务? 2.默认情况下每一条sql语句都是一个事务,然后自动提交事务 ps:如果想多条语句占一个事务,则可以手动设置SetAutoCommit为false 3.关键字 start tr ...
- 乐观锁的颗粒度_MySql数据库锁机制详解
概述 数据库锁定机制简单的来说,就是数据库为了保证数据的一致性与完整性,而使各种共享资源在被并发访问时变得有序所设计的一种规则.对于任何一种数据库来说都需要有相应的锁机制,所以MySQL也不能例外.M ...
- Mysql 数据库锁机制浅析
锁机制根据不同的存储引擎表现不一样,下面分析MyISAM存储引擎与InnoDB两种存储引擎. 一,MyISAM 1,该引擎采用的是表级锁,有: 读锁:表级读共享锁: 写锁:表级独占锁. 具体表现为: ...
- MySQL数据库锁机制之MyISAM引擎表锁和InnoDB行锁详解
MySQL中的锁概念 Mysql中不同的存储引擎支持不同的锁机制.比如MyISAM和MEMORY存储引擎采用的表级锁,BDB采用的是页面锁,也支持表级锁,InnoDB存储引擎既支持行级锁,也支持表级锁 ...
- MySQL数据库——锁机制
1 认识锁机制 在认识锁机制前,首先思考一个问题:在同一时刻,用户A和用户B同时要获取并修改sh_goods表中id等于2的stock库存量值,此时会发生什么呢? 假设在初始情况下,sh_ goods ...
- 数据库锁机制的详细解释
T1: select * from table (请想象它需要执行1个小时之久,后面的sql语句请都这么想象) T2: update table set column1='hello' 过程: T1运 ...
最新文章
- python基础语法手册format-Python基础语法-格式化输出
- 【Python】url基础:urllib
- React开发(154):注意div得写法
- php 实现的n,php 实现数据N等分。
- android 混合开发 图片,混合开发的大趋势之一React Native之Image
- 工程之道 | CPU推理性能提高数十倍,MegEngine计算图、MatMul优化解析
- 【hortonworks/registries】SchemaVersionLifecycleManager.createSchemaVersion null
- 关于集合addAll()方法的坑度
- simulink中积分环节、惯性环节、比例环节
- CST材料库相关问题
- 51单片机与AVR单片机
- 跨境支付产品:现钞与现汇
- 微波射频网将举办“微带传输线无源交调测试可重复性”在线技术讲座
- 前后端分离与耦合架构
- dreamweaver cs4 css汉化补丁,dreamweaver cs4官方版
- 如何实现受管控的安全文件传输MFT?
- 6--目标检测和边界框和锚框
- WslRegisterDistribution failed with error: 0x80370102 Error: 0x80370102 ???????????????????
- Java上路09-多线程
- 微信小程序如何实现同时授权用户信息和手机号码不重复授权问题
热门文章
- 关于python中使用pyqt5时出现:Process finished with exit code -1073741819 (0xC0000005)
- zzuli 20级新生周赛(1)题解
- The XOR Largest Pair(01trie模板题)
- 哈尔滨理工大学软件与微电子学院程序设计竞赛 题解
- 枚举算法 C语言 试题,求代码:如图大体思路是,用枚举法,一个个的试,碰到非的情况从...
- python rsa 公钥解密_python利用rsa库做公钥解密的方法教程
- oracle symonym_oracle vs. SQL 同义词synonym 别名 alias | 学步园
- STM32配置一般过程(持续更新中)
- POJ2352:Stars——题解
- BeanShell中的Java指令和表达式