mysql数据库死锁原理(MySQL数据库锁机制原理解析)
mysql数据库死锁原理
MySQL数据库锁机制原理解析在并发访问情况下,很有可能出现不可重复读等等读现象。为了更好的应对高并发,封锁、时间戳、乐观并发控制(乐观锁)、悲观并发控制(悲观锁)都是并发控制采用的主要技术方式。
锁分类
①、按操作划分:DML锁,DDL锁
②、按锁的粒度划分:表级锁、行级锁、页级锁
③、按锁级别划分:共享锁、排他锁
④、按加锁方式划分:自动锁、显示锁
⑤、按使用方式划分:乐观锁、悲观锁
乐观锁和悲观锁
乐观并发控制和悲观并发控制是并发控制采用的主要方法。乐观锁和悲观锁不仅在关系数据库里应用,在Hibernate、Memcache等等也有相关概念。
悲观锁:也即悲观并发控制,Pessimistic Concurrency Controller,缩写PCC。悲观锁是指在数据处理过程,使数据处于锁定状态,一般使用数据库的锁机制实现。
备注,在MySQL中使用悲观锁,必须关闭MySQL的自动提交,set autocommit=0。MySQL默认使用自动提交autocommit模式,也即你执行一个更新操作,MySQL会自动将结果提交。
例如:使用select...for update方式将数据锁住,也就是开启了排他锁
|
//0.开始事务 begin ;/ begin work ;/start transaction ; (三者选一就可 //1.查询出商品信息 select status from t_goods where id=1 for update ; //2.根据商品信息生成订单 insert into t_orders (id,goods_id) values ( null ,1); //3.修改商品status为2 update t_goods set status=2; //4.提交事务 commit ;/ commit work ; |
悲观锁
优点:悲观锁利用数据库中的锁机制来实现数据变化的顺序执行,这是最有效的办法
缺点:加锁机制会产生额外的开销,增加产生死锁的机会。一个事务用悲观锁对数据加锁之后,其他事务将不能对加锁的数据进行除了查询以外的所有操作,如果该事务执行时间很长,那么其他事务将一直等待,那势必影响我们系统的吞吐量。
乐观锁
优点:乐观锁不在数据库上加锁,任何事务都可以对数据进行操作,在更新时才进行校验,这样就避免了悲观锁造成的吞吐量下降的劣势。
缺点:乐观锁因为是通过我们人为实现的,它仅仅适用于我们自己业务中,如果有外来事务插入,那么就可能发生错误。
- MySQL常用存储引擎的锁机制
- BDB:支持页级锁和表级锁,默认是页级锁
- InnoDB:支持行级锁和表级锁,默认是行级锁
- MyISAM &Memory:这两个存储引擎都是采用表级锁
MySQL中排它锁和共享锁
排它锁(exclusive locck)
排它锁又叫写锁,如果事务T对A加上排它锁,则其它事务都不能对A加任何类型的锁。获准排它锁的事务既能读数据,又能写数据。
用法:SELECT ... FOR UPDATE
共享锁(share lock)
共享锁又叫读锁,如果事务T对A加上共享锁,则其它事务只能对A再加共享锁,不能加其它锁。获准共享锁的事务只能读数据,不能写数据。
用法:SELECT ... LOCK IN SHARE MODE;
MySQL中的行级锁、表级锁和页级锁
行级锁:行级锁分为共享锁和排它锁。行级锁是Mysql中锁定粒度最细的锁。InnoDB引擎支持行级锁和表级锁,只有在通过索引条件检索数据的时候,才使用行级锁,否就使用表级锁。行级锁开销大,加锁慢,锁定粒度最小,发生锁冲突概率最低,并发度最高
表级锁:表级锁分为表共享锁和表独占锁。表级锁开销小,加锁快,锁定粒度大、发生锁冲突最高,并发度最低
页级锁:页级锁是MySQL中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录。BDB支持页级锁。
开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://www.cnblogs.com/123-shen/p/11361620.html
- mysqlmha架构图(MySQL之MHA高可用配置及故障切换实现详细部署步骤)
- mysql主从复制忽略问题(MySQL复制问题的三个参数分析)
- mysql各种锁详解(MySQL 查看事务和锁情况的常用语句分享)
- mysql8.0.26安装教程(mysql 8.0.22压缩包完整安装与配置教程图解亲测安装有效)
- visual studio怎么连接数据库(使用Visual Studio Code连接MySql数据库并进行查询)
- mysql主从复制时突然来了一批数据(MySQL主从复制断开的常用修复方法)
- mysql常用的sql语句大全(mysql建表常用的sql语句汇总)
- mysql所有用户命令(MySQL用户管理与PostgreSQL用户管理的区别说明)
- mysql的默认隔离级别(再有人问你MySQL的隔离级别是什么,就把这篇文章发给他!)
- mysql索引原理及调优(mysql高级学习之索引的优劣势及规则使用)
- php7用什么替代mysql(mysqli扩展无法在PHP7下升级问题的解决)
- mysql错误代码之1064的解决方案(mysql错误代码之1064的解决方案)
- mysql集群是用什么搭建的(MySQL5.7 集群配置的步骤)
- mysqljson字段查询(Mysql 查询JSON结果的相关函数汇总)
- mysql全表查询如何优化(MySQL 分组查询的优化方法)
- mysql的innodb引擎数据结构(MySQL InnoDB架构的相关总结)
- 入秋后的第二场苹果发布会来了 全新M1系列芯片登场(入秋后的第二场苹果发布会来了)
- 苹果正式发布自研芯片M1 5nm 32核心 彻底放弃Intel(苹果正式发布自研芯片M1)
- 苹果自研芯片跑分对比 A16芯片排名靠后,M1系列霸榜(苹果自研芯片跑分对比)
- X86处理器的梦魇 苹果M1自研芯片到底有多强(苹果M1自研芯片到底有多强)
- 泰剧《爱欲之神》Boom kitkong和Great合体杂志(泰剧爱欲之神Boomkitkong和Great合体杂志)
- 素人恋爱综艺火药味十足 男生为赢得芳心集体扯头花,真是出好戏(素人恋爱综艺火药味十足)
热门推荐
- 查看腾讯云服务器端口(腾讯云服务器解封25端口图文教程)
- mysql意外查不到数据(MySQL 丢失数据的原因及解决)
- python3循环使用教程(Python3.5常见内置方法参数用法实例详解)
- nginx网站集群(Nginx实现高可用集群构建Keepalived+Haproxy+Nginx)
- 云计算是一种服务的概念(云服务的意思,云服务是云计算吗?)
- laravel自定义使用方法(laravel 修改.htaccess文件 重定向public的解决方法)
- javascript将字符串转换成数组(如何将JavaScript将数组转为树形结构)
- sqlserver存储过程同步数据(SQL Server存储过程同时返回分页结果集和总数)
- js实现CSS格式化和压缩
- dedecms表单格式(DedeCMS arclist的分页使用教程)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9