MySQL 下不同存储引擎下锁的不同表现形式|学习笔记

简介: 快速学习 MySQL 下不同存储引擎下锁的不同表现形式

开发者学堂课程【MySQL 实操课程MySQL 下不同存储引擎下锁的不同表现形式】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/717/detail/12817


MySQL 下不同存储引擎下锁的不同表现形式

 

一、MYSQL

1、MySQL 下不同存储引擎下,锁的不同表现形式

(1锁定义与 MySQL 不同存储引擎下锁的表现形式

数据库锁机制简单来说,就是数据库为了保证数据的一致性,使各种共享资源在被并发访问时变得有序而设计的一种规则;

详解:

主要是对比事物,事物就是为了保证数据的一致性,如何确保在 MySQL 并发访问下的一致性?事物只能保证当前事物的一致性,并不能保证并发的,所以引出了锁,在资源并发访问时变得有序。

(2)MySQL 不同的存储引擎支持不同的锁机制

In no DB 支持行锁,有时会升级为表锁; My ISAM 只支持表锁

表锁:开销小、加锁快;不会出现死锁;锁粒度大,发生锁冲突概率高,并发

③行锁:开销大、加锁慢;会出现死锁;锁粒度小,发生锁冲突概率低,并发

详解:

在某个表中每行表中都有单独的数据,对表加锁并不会对整个表加锁,这种现象可能会出现死锁,特别是在相互等待的情况下;MySQL 数据库对死锁会有自动处理机制和超时机制,并会无限阻塞。从另一个角度讲,此锁分别为显示锁和隐示锁,之前所讲的隐示提交和显示提交便与之对应,隐示是指大家不需要手动加锁,本身会加锁;显示就需要手动加锁。

My ISAM 只支持表锁指的是 My ISAM 在执行查询和更新操作时,会使用到隐示添加表锁,隐示锁不但不受数据库开发人员的控制,并且生命周期短暂,为了延长表锁的生命周期,会显示的去添加表锁或显示解锁。

(3)举例:如何给 MySQL 表施加表级锁?

①打开 shell 窗口,如下图:

图片1.png

进入阿里云的云命令窗口,先链接 MySQL 的示例,需要进行清屏后输入 id,打开一个窗口后需打开第二个窗口,为了实验方便,这里只开两个窗口;接下来访问示例,复制内网地址再回车,另一个窗口的操作一样,输入“-h”后加上内网地址再回车;同样采取之前的实验数据,使用阿里云,user 表和 user-back 表,如下图:

图片2.png

两个表的结构和内容是一样的,不一样的地方在 show create table user,如下图:

两个表中“ENGINE=In no DB”都是基于 In no DB 的存储引擎。

(4)在 In no DB 存储引擎和 MySQL 存储引擎下的表现形式是怎样的?

①为了演示方便,表中的内容不适合 MySQL 的存储引擎,所以退出后使用本地示例,接下来的操作也是如此,可以看到 MySQL 的 show tables 图片3.png如下:

图片4.png

以下是 MySQL 的 user 表和 user-back 表图示:

图片5.png

这是两个不同的存储引擎,在此是为了演示,所以用的不同的存储引擎。

(5)接下来测试 user-back(为了观察在做显示时,有什么影响)

①输入 from user-back,详情如下:

图片6.png

这是 MySQL 的存储引擎,接下来输入 being,再修改某一条数据,把表中的zhangsan2 改成 zhangsan, 可查询到以下结果:

可以看到名字改成功了,再来回滚一下,看是否能回到 zhangsan2,结果告诉并不会再回到 zhangsan2,这样更图片8.png

行无操作,大家还能继续查询,如图:

注意,这时不能继续查询 user 表,会出提示;如果后面要查询的表没有在前面的表中进行锁定,便会报错,所以需要在前面表的基础之下进行操作;

接下来进行修改,输入“update user-bak set name=zhangsan2where id=1”,在另一边同样去执行,先执行一次查询。输入“select *from user-bak”,之后会直接进行阻塞,因为整个表已经被属定,其中一个表执行的 look,这边去执行还是不行;要是去查 ID=2 的,同样不行。需要注意的是第一个表执行了 look 和write,第二个表是不能进行查询和改写的。这是大家的机制。要想执行成功,需unlock tables 查询成功后方可执行,这是对于锁写操作。

对锁读的操作,输入“look tables user-bak read”,在另一个表中是可以进行查询的,进行锁读操作后,另一边可以对用户端进行查询,但是不能进行改写。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
7月前
|
SQL AliSQL 关系型数据库
MYSQL的全局锁和表锁
本文介绍了MySQL中的锁机制,包括全局锁、表级锁及其应用场景。全局锁通过`Flush tables with read lock (FTWRL)`实现,主要用于全库逻辑备份,但会阻塞更新和结构变更操作。表级锁分为显式表锁(`lock tables`)和元数据锁(MDL),前者用于控制并发访问,后者自动加锁以确保读写正确性。文章还探讨了如何安全地为小表添加字段,建议通过设置DDL等待时间或使用MariaDB/AliSQL的NOWAIT/WAIT功能避免业务阻塞。这些方法有助于在高并发场景下优化数据库性能与安全性。
197 0
|
7月前
|
存储 SQL 关系型数据库
MySQL存储引擎简介
在选择相应的存储引擎时,需要充分考虑实际业务场景、性能需求和数据一致性要求,从而为数据管理提供最佳支持。
400 17
|
11月前
|
存储 关系型数据库 MySQL
MySQL索引学习笔记
本文深入探讨了MySQL数据库中慢查询分析的关键概念和技术手段。
735 81
|
12月前
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
2028 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
10月前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
414 25
|
9月前
|
存储 关系型数据库 MySQL
MYSQL支持的存储引擎有哪些, 有什么区别
MYSQL存储引擎有很多, 常用的就二种 : MyISAM和InnerDB , 者两种存储引擎的区别 ; ● MyISAM支持256TB的数据存储 , InnerDB只支持64TB的数据存储 ● MyISAM 不支持事务 , InnerDB支持事务 ● MyISAM 不支持外键 , InnerDB支持外键
|
11月前
|
存储 关系型数据库 MySQL
MySQL进阶突击系列(06)MySQL有几种锁?| 别背答案,现场演示一下
本文详细解析了MySQL InnoDB存储引擎的锁机制,涵盖读锁、写锁、意向锁、记录锁、间隙锁和临键锁等8种锁类型。重点探讨了不同锁类型的加锁与释放方式,以及事务并发场景下的实战验证。通过具体示例,展示了在不同情况下锁的行为及其对事务的影响。文章还特别强调了锁的作用范围主要是索引,并解释了锁如何影响数据的读写操作。最后总结了并发事务中加锁规则,帮助读者深入理解MySQL的锁机制。
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
544 7
|
存储 SQL 关系型数据库
MySQL存储引擎
本文介绍了数据库优化的多个方面,包括选择合适的存储引擎、字段定义原则、避免使用外键和触发器、大文件存储策略、表拆分及字段冗余处理等。强调了从业务层面进行优化的重要性,如通过活动设计减少外部接口调用,以及在高并发场景下的流量控制与预处理措施。文章还提供了具体的SQL优化技巧和表结构优化建议,旨在提高数据库性能和可维护性。
385 1
MySQL存储引擎
|
SQL 关系型数据库 MySQL
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结
MySQL中用于数据检索的`fetchone()`, `fetchmany()`, `fetchall()`函数的功能、SQL语句示例和应用场景。
408 3
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结

推荐镜像

更多