mysql各种锁总结

mysql全局锁

读锁(共享锁)

阻止其他用户更新,但允许他们读取数据。

写锁(排他锁)

阻止其他用户读取和更新数据。
全局锁场景:进行数据库备份

数据库备份

背景:备份数据肯定要保证数据一致性,比如你备份数据的时候插入或者修改了数据,肯定造成数据错乱。如果是那种订单表和套餐表。原来套餐表没有数据,如果备份过程中没有加锁,写入了一条98超值双人套餐记录

备份方式一

表结构

DROP TABLE IF EXISTS `bk_book`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `bk_book` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,`title` varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '标题',`short_description` varchar(500) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '简短介绍',`description` varchar(1000) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '简介',`abstract` varchar(1000) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '摘要信息',`is_finished` smallint(3) DEFAULT '1' COMMENT '是否完结 1是 其他否',`release_time` datetime DEFAULT NULL COMMENT '上架时间',`published_day` date DEFAULT NULL COMMENT '出版日期',`isbn` char(15) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT 'ISBN',`main_source_id` bigint(20) NOT NULL DEFAULT '0' COMMENT '主站ID,主要用来标记信息体主要来源',`state` smallint(11) DEFAULT '1' COMMENT '状态 1可用 其他不可用',`is_indexed` tinyint(2) NOT NULL DEFAULT '0' COMMENT '标记是否已经更新到bk_index, 1是 0否',`created_at` datetime DEFAULT NULL COMMENT '创建时间',`updated_at` datetime DEFAULT NULL,`is_manual` int(4) NOT NULL DEFAULT '0' COMMENT '是否人工录入 1:是 0:否',`rating_label` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',`word_count` int(11) NOT NULL DEFAULT '0' COMMENT '书籍字数,审核后台排序使用',`title_alias` varchar(1000) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '标题别名',`type` int(1) NOT NULL DEFAULT '1' COMMENT '图书的类型:1-txt,2-epub,3-pdf',`sub_type` int(4) NOT NULL DEFAULT '1' COMMENT '图书的类型:1-txt,2-epub,3-pdf,40-条漫,41-页面',`add_by` tinyint(4) NOT NULL DEFAULT '1' COMMENT '图书内容接入方式:1-api.2-spider,3-sdk',`url` varchar(1000) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT 'epub/pdf图书的下载地址',`off_reason` varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT '下架理由',`content_type` int(1) NOT NULL DEFAULT '1' COMMENT '图书内容类型:1-cp,2-非cp',`repeat_book_id` varchar(1000) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '重复的图书id',PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1676792430644794443 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;--
-- Dumping data for table `bk_book`
--
INSERT INTO `bk_book` VALUES (1530436864545149217,'绝世剑神','','天灵大陆,武道为尊!强者可以遨游天地,威震山河,弹指日月变色,翻手苍穹覆灭!神州大地年轻的武学宗师林辰,意外带着一尊神秘小鼎来到这个世界,成为雁南域天极宗的外门弟子。自此,海阔凭鱼跃,天高任鸟飞!且看林辰如何在这异界一步步踏上巅峰,凌九霄,破万劫,终成一代绝世剑神','',0,'1900-01-01 00:00:00','1900-01-01','',70,1,1,'2022-05-28 14:32:37','2023-01-03 14:20:47',1,'N',15329571,'[]',1,0,1,'http://api.yuedu.163.com/source/31762008','合约到期自动下线',1,'')
/*!40000 ALTER TABLE `bk_book` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

1、设置表只读模式 flush tables with read lock;
2、新的终端执行更新UPDATE base_book.bk_bookSETstate= 0 WHEREid = 1530436864545149217;发现一只在转圈就是被锁住了
3、备份数据库 mysqldump -uroot -p3306 base_book bk_book >bk_book.sql
4、备份完毕后执行unlock tables; 释放锁
最后发现锁解除就能成功更新sql语句了

备份方式二

利用mysql 的MVCC多版本并发控制,他可以保证数据一致性,能够保证数据库备份时保证。
–single-transaction:使用 --single-transaction 可以避免在备份大型数据库时出现长时间的锁定或阻塞现象,对生产环境的业务操作影响较小。但需要注意的是,备份的数据库引擎必须支持事务(如 InnoDB 引擎),如果使用的是 MyISAM 等不支持事务的引擎,该选项将被忽略。
mysqldump --single-transaction -uroot -p3306 base_book bk_book > bk_book.sql同样达到数据一致性效果并且不用加锁。

表级锁

发生情况:
1、alter table
修改表:比如添加列、删除列、改变列类型。会造成整个表被锁住
2、drop table 删除整个表 和truncate table 删除表所有数据。
会造成整个表被锁住
3、lock tables:加一个或者多个表的锁 。lock tables t1 write,t2 read 会给t1 表加写锁,给t2表加读锁。

行锁

行锁只在事务中生效,在事务开启和提交或回滚前,才能对数据锁定。如果在非事务环境中执行slq语句,那么innodb在语句执行后就会立即释放所有锁。

共享锁(S锁)即读锁

排他锁(X锁)即写锁

导致行锁的情况

1、select … for update 悲观锁:这种查询会对选定的行添加一个排他锁(X锁 写锁),意味着其他事务不能修改这些行, 也不能对这些行添加共享锁(读锁)。
2、select … lock in share mode 这种会对选定的行添加一个共享锁(S锁),意味着其他事务不能修改这些行,但是可以添加共享锁(读锁)。
3、insert:插入操作会对新添加的行添加一个排他锁-X锁-写锁
4、update:更新操作会对被更新的行添加一个排他锁-X锁-写锁
5、delete:删除操作会对被删除的行添加一个 排他锁-X锁-写锁

这些锁是在事务中进行的,在事务开启和提交或回滚前,才能对数据锁定。如果在非事务环境中执行slq语句,那么innodb在语句执行后就会立即释放所有锁。

乐观锁和悲观锁

乐观锁

场景:
1、短事务操作
2、分布式系统
3、读多写少

悲观锁

场景:
1、写多读少
2、并发冲突高
3、业务需要强一致性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/49827.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu 重置root密码

Ubuntu 重置root密码 当系统管理员或者授权用户忘记了root密码时,重置密码能够提供紧急访问系统的方法。这种情况下,重置密码可以避免因为密码丢失而导致的系统无法访问的问题,确保及时的操作和维护。在进行系统安全审计或者需要紧急恢复访问…

Top K问题及解决

Top K问题及解决 Top K问题:在大规模数据处理中,经常会需要在海量数据中找出频率最高的前K个数。比如,在搜索引擎中,统计搜索最热门的10个查询词等。针对Top K类问题,可以使用分治算法Trie树/hash 小/大顶堆&#xff…

Go 语言条件变量 Cond

1.Cond 的使用方法 Go 标准库提供 Cond 同步原语的目的是为等待/通知场景下的并发操作提供支持。Cond 通常用于等待某个条件的一组 goroutine,当条件变为 true 时,其中一个或者所有的 goroutine 会被唤醒执行。 Cond 与某个条件相关,这个条件需要一组 goroutine 协作达到。当这…

HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 多选题序号5

基础认证题库请移步:HarmonyOS应用开发者基础认证题库 注:有读者反馈,题库的代码块比较多,打开文章时会卡死。所以笔者将题库拆分,单选题20个为一组,多选题10个为一组,题库目录如下,…

【学一点儿前端】getaddrinfo ENOTFOUND registry.nlark.com“.

问题 今天jenkins打包一个项目,发现报错了 error An unexpected error occurred: "https://registry.nlark.com/xxxxxxxxxx.tgz: getaddrinfo ENOTFOUND registry.nlark.com". 先写解决方案 把yarn.lock文件里面的registry.nlark.com替换为registry.npmmi…

<数据集>抽烟识别数据集<目标检测>

数据集格式:VOCYOLO格式 图片数量:4860张 标注数量(xml文件个数):4860 标注数量(txt文件个数):4860 标注类别数:1 标注类别名称:[smoking] 使用标注工具:labelImg 标注规则:对…

Python3 第四十课 -- 实例九

目录 一. 十进制转二进制、八进制、十六进制 1.1. 二进制转换实例 1.2. 八进制转换实例 1.3. 十六进制转换实例 一. 十进制转二进制、八进制、十六进制 以下代码用于实现十进制转二进制、八进制、十六进制: # -*- coding: UTF-8 -*-# Filename : test.py # au…

uni-app云函数中使用mqtt接收消息

const mqtt require(mqtt);exports.main async (event, context) > {return new Promise((resolve, reject) > {// 连接到 MQTT 服务器const client mqtt.connect(wss://mqtt.example.com:8083/mqtt, {username: your-username,password: your-password,});// 连接成功…

spring —— spring 整合 junit

如果不使用 spring 整合 junit,每次取对象时都要建立 spring 容器,然后从 spring 容器中提取对象,也就是以下两行代码: //建立spring容器 ApplicationContext context new ClassPathXmlApplicationContext("xxx.xml")…

探索 IPython %%sql 魔术:数据库交互的高效工具

探索 IPython %%sql 魔术:数据库交互的高效工具 在数据科学和分析领域,IPython 提供了一个强大的交互式环境,允许用户执行 Python 代码并与各种数据源进行交互。%%sql 魔术命令是 IPython 环境中的一个特殊命令,它允许用户直接在…

【时间动作定位】End-to-end Temporal Action Detection with Transformer 论文阅读

End-to-end Temporal Action Detection with Transformer 论文阅读 AbstractI. INTRODUCTIONII. RELATED WORKIII. TADTRA. ArchitectureB. Training and Inference IV. EXPERIMENTSV. CONCLUSION 文章信息: 发表于: IEEE Transactions on Image Proce…

四、GD32 MCU 常见外设介绍 (7) 7.I2C 模块介绍

7.1.I2C 基础知识 I2C(Inter-Integrated Circuit)总线是一种由Philips公司开发的两线式串行总线,用于内部IC控制的具有多端控制能力的双线双向串行数据总线系统,能够用于替代标准的并行总线,连接各种集成 电路和功能模块。I2C器件能够减少电…

【MQTT协议与IoT通信】MQTT协议的使用和管理

MQTT协议与IoT通信:MQTT协议的使用和管理 目录 引言MQTT协议概述 什么是MQTTMQTT的工作原理 MQTT协议的关键特性 轻量级与高效性发布/订阅模式质量服务等级(QoS)持久会话安全性 MQTT协议的使用方法 设置MQTT Broker连接MQTT Client发布消息订阅主题断开连接 MQTT协…

策略+工厂设计模式的应用

问题 比如有下面一段业务,一个自动售货机,根据用户选择不同的饮料,出对应的货 public class NoDesignDemo {public void ifElse(String parameter) {if ("Pepsi".equalsIgnoreCase(parameter)) {System.out.println("百事可…

[ptrade交易实战] 第十八篇 期货查询类函数和期货设置类函数

前言 今天主要和大家分享的是期货查询类的函数和期货设置类的函数! 具体的开通渠道可以看文章末尾! 一、get_margin_rate—— 获取用户设置的保证金比例 保证金是期货交易中的一个重点,这个函数就是用来获取我们设置的保证金比例的&#…

整合StarRocks主键表全部知识点

总结StarRocks主键表的全部内容的集合(V3.2版本) 一、基本功能 主键非空约束,任何一个字段都不可以为空支持导入数据时删除数据操作(CDC)支持部分更新支持独立的排序键(只有主键表支持独立排序键,而且可以不为key键&…

极限科技闪耀 2024 可信数据库发展大会,多款自研产品引领搜索技术新纪元

北京,7 月 16、17 日 —— 在由中国信息通信研究院(中国信通院)与中国通信标准化协会联合主办,InfoQ 协办的“2024 可信数据库发展大会”(TDBC 2024)上,极限科技凭借其前沿的搜索技术创新与卓越…

【相机与图像】1. 相机模型的介绍:内参、外参、畸变参数

想着整理下相机模型(内容上参考 slam十四讲)、相机的内外参标定。方便自己的使用和回顾。 不过,内外参标定啥时候记录随缘 -_- 概述 【构建相机模型】 相机将三位世界中的坐标点(单位为米)映射到二维图像平面&#xff…

py Qt5学习记录

1.Qt5的安装 可参考一些博客如:Python 小白从零开始 PyQt5 项目实战(2)菜单和工具栏_pyqt 二级菜单-CSDN博客 2.Qt5的界面显示 3.新建一个工具栏并打开本地文件方法 (1)在Qt5界面右下角有个“动作编辑器”&#xff…

学习笔记5:缓存穿透

缓存穿透 缓存穿透是指在缓存系统中,当一个请求的查询结果为空时,这个请求会直接穿透缓存系统,访问后端的数据库。如果这种情况频繁发生,会对数据库造成较大的压力,甚至可能导致数据库崩溃。 在正常情况下&#xff0…