iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >如何进行MySQL metadata锁实验
  • 573
分享到

如何进行MySQL metadata锁实验

2024-04-02 19:04:59 573人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关如何进行Mysql metadata锁实验,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 在对已经存

这篇文章将为大家详细讲解有关如何进行Mysql metadata实验,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

在对已经存在的表执行DDL语句(例如更改表结构、DROP表等操作)的时候,如果有与这个表相关联的事务没有提交,就会产生metadata锁等待。
这个时候,需要提交与这张表相关联的事务,才会将metadata锁释放。

创建一张表
mysql> CREATE TABLE `travelrecord` (
    ->        `id` bigint(20) NOT NULL,
    ->        `user_id` varchar(100) DEFAULT NULL,
    ->        `traveldate` date DEFAULT NULL,
    ->        `fee` decimal(10,0) DEFAULT NULL,
    ->        `days` int(11) DEFAULT NULL,
    ->        PRIMARY KEY (`id`)
    ->      ) ENGINE=InnoDB DEFAULT CHARSET=gbk;
Query OK, 0 rows affected (0.09 sec)

会话一
开启一个事务,查询新创建的表
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from travelrecord;
Empty set (0.00 sec)
会话二
drop刚刚创建的表,会发生锁等待
mysql> drop table travelrecord;


会话一
查询会话
mysql> show processlist;
+----+------+-----------------+------+---------+------+---------------------------------+-------------------------+
| Id | User | Host            | db   | Command | Time | State                           | Info                    |
+----+------+-----------------+------+---------+------+---------------------------------+-------------------------+
|  3 | root | 127.0.0.1:34875 | sale | Query   |    0 | init                            | show processlist        |
| 24 | root | 127.0.0.1:34876 | sale | Query   | 1058 | Waiting for table metadata lock | drop table travelrecord |
+----+------+-----------------+------+---------+------+---------------------------------+-------------------------+
2 rows in set (0.00 sec)

提交事务
mysql> commit;
Query OK, 0 rows affected (0.03 sec)

会话二
锁释放,DROP语句顺利执行
mysql> drop table travelrecord;
Query OK, 0 rows affected (58 min 40.02 sec)

数据库中没有了锁
mysql> show processlist;
+----+------+-----------------+------+---------+------+-------+------------------+
| Id | User | Host            | db   | Command | Time | State | Info             |
+----+------+-----------------+------+---------+------+-------+------------------+
|  3 | root | 127.0.0.1:34875 | sale | Sleep   |   76 |       | NULL             |
| 24 | root | 127.0.0.1:34876 | sale | Query   |    0 | init  | show processlist |
+----+------+-----------------+------+---------+------+-------+------------------+
2 rows in set (0.00 sec)

关于如何进行MySQL metadata锁实验就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: 如何进行MySQL metadata锁实验

本文链接: https://www.lsjlt.com/news/66076.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何进行MySQL metadata锁实验
    这篇文章将为大家详细讲解有关如何进行MySQL metadata锁实验,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 在对已经存...
    99+
    2024-04-02
  • Mysql锁机制中行锁、表锁、死锁如何实现
    这篇文章主要介绍了Mysql锁机制中行锁、表锁、死锁如何实现,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、Mysql锁是什么?锁有哪些类别?锁定义:  ...
    99+
    2023-06-29
  • 如何进行MySQL加锁处理的分析
    如何进行MySQL加锁处理的分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 1. 准备测试数据use t...
    99+
    2024-04-02
  • mysql如何加行锁
    小编给大家分享一下mysql如何加行锁,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!创建行锁条件:1、表中创建索引, select ... where   字段(...
    99+
    2024-04-02
  • 如何优化mysql行锁
    如何优化mysql行锁?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、优化方法尽可能让所有数据检索都通过索引来完成,避免无索引行或索引失效导致行锁升级为表锁。尽可能避免间...
    99+
    2023-06-15
  • 如何理解MySQL行锁、表锁、间隙锁
    本篇内容介绍了“如何理解MySQL行锁、表锁、间隙锁”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!准备工作...
    99+
    2024-04-02
  • 怎么进行mysql的sync_binlog参数实验
    今天就跟大家聊聊有关怎么进行mysql的sync_binlog参数实验,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 m...
    99+
    2024-04-02
  • MySQL中如何进行XtraBackup实战
    这篇文章给大家介绍MySQL中如何进行XtraBackup实战,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.使用xtrabckup对mysql进行全备mysql1@hdh-vots...
    99+
    2024-04-02
  • MySQL 行锁超如何排查
    MySQL 行锁超如何排查,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 一、大纲#### 20191219 ...
    99+
    2024-04-02
  • 如何对参数进行校验
    本篇内容主要讲解“如何对参数进行校验”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何对参数进行校验”吧!背景大部分的方法和构造函数对传入的参数值有一些限制,比...
    99+
    2024-04-02
  • SpringBoot如何进行参数校验实例详解
    目录前言为什么需要参数校验SpringBoot中集成参数校验第一步,引入依赖第二步,定义要参数校验的实体类第三步,定义校验类进行测试第四步,体验效果参数异常加入全局异常处理器体验效果...
    99+
    2024-04-02
  • SpringBoot如何进行业务校验实例详解
    目录前言为什么需要Assert?如何使用Assert加入全局异常拦截器常见的Assert使用场景小结总结前言 今天继续来聊聊在SpringBoot项目中如何实现业务异常校验Asser...
    99+
    2024-04-02
  • 如何进行Redlock中Redis分布式锁的实现
    这篇文章将为大家详细讲解有关如何进行Redlock中Redis分布式锁的实现,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。普通实现说道Redis分布式锁大部分人都会想到:setnx+lua,...
    99+
    2023-06-02
  • Mysql锁机制之行锁、表锁、死锁的实现
    目录一、Mysql锁是什么?锁有哪些类别?二、行锁和表锁的区别三、InnoDB死锁概念和死锁案例死锁场景一之select for update:死锁场景二之两个update...
    99+
    2024-04-02
  • 如何解决mysql行锁问题
    解决mysql行锁问题的方法打开mysql终端命令符窗口,根据以下步骤解决。查询是否锁表,代码:“show OPEN TABLES where In_use > 0;”查询进程,代码:“show processlist”,再...
    99+
    2024-04-02
  • 如何进行SAP替代与校验
    如何进行SAP替代与校验,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。替代GGB12a、FI自动替代(substitution)时怎样把BESG表里的某个字段放出来?&nb...
    99+
    2023-06-05
  • mysql如何进行进制转换
    小编给大家分享一下mysql如何进行进制转换,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! mysql进制转换方法:1、利用“bin(值)”,可将十进...
    99+
    2024-04-02
  • 如何进行innodb 事务锁的研究
    今天就跟大家聊聊有关如何进行innodb 事务锁的研究,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. select * for upd...
    99+
    2024-04-02
  • MySQL如何进行管理
    本篇内容主要讲解“MySQL如何进行管理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL如何进行管理”吧! 对于内容驱动的...
    99+
    2024-04-02
  • MySQL如何进行优化
    这篇文章主要讲解了“MySQL如何进行优化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL如何进行优化”吧! 案例背景案例分析MySQL ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作