一、关于锁的三张表(MEMORY引擎)
  
  ## 当前运行的所有事务
  
  mysql> select * from information_schema.innodb_trx\G;
  
  *************************** 1. row ***************************
  
  trx_id: 613963
  
  trx_state: LOCK WAIT #事务状态
  
  trx_started: 2019-02-22 10:48:48
  
  trx_requested_lock_id: 613963:460:3:4
  
  trx_wait_started: 2019-02-22 11:08:41
  
  trx_weight: 2
  
  trx_mysql_thread_id: 140
  
  trx_query: update tx1 set c1='heyfffff',c2='heyffffff' where id =3
  
  trx_operation_state: starting index read
  
  trx_tables_in_use: 1
  
  trx_tables_locked: 1
  
  trx_lock_structs: 2
  
  trx_lock_memory_bytes: 1136
  
  trx_rows_locked: 7 #事务锁住的行数
  
  trx_rows_modified: 0
  
  trx_concurrency_tickets: 0 #事务并发票数
  
  trx_isolation_level: REPEATABLE READ
  
  trx_unique_checks: 1
  
  trx_foreign_key_checks: 1
  
  trx_last_foreign_key_error: NULL
  
  trx_adaptive_hash_latched: 0
  
  trx_adaptive_hash_timeout: 0
  
  trx_is_read_only: 0
  
  trx_autocommit_non_locking: 0
  
  *************************** 2. row ***************************
  
  trx_id: 613962
  
  trx_state: RUNNING
  
  trx_started: 2019-02-22 10:46:29
  
  trx_requested_lock_id: NULL
  
  trx_wait_started: NULL
  
  trx_weight: 3
  
  trx_mysql_thread_id: 138
  
  trx_query: select * from information_schema.innodb_trx
  
  trx_operation_state: NULL
  
  trx_tables_in_use: 0
  
  trx_tables_locked: 1
  
  trx_lock_structs: 2
  
  trx_lock_memory_bytes: 1136
  
  trx_rows_locked: 1
  
  trx_rows_modified: 1
  
  trx_concurrency_tickets: 0
  
  trx_isolation_level: REPEATABLE READ
  
  trx_unique_checks: 1
  
  trx_foreign_key_checks: 1
  
  trx_last_foreign_key_error: NULL
  
  trx_adaptive_hash_latched: 0
  
  trx_adaptive_hash_timeout: 0
  
  trx_is_read_only: 0
  
  trx_autocommit_non_locking: 0
  
  2 rows in set (0.00 sec)
  
  ## 当前出现的锁
  
  mysql> select * from information_schema.innodb_locks\G;
  
  *************************** 1. row ***************************
  
  lock_id: 613963:460:3:4
  
  lock_trx_id: 613963
  
  lock_mode: X
  
  lock_type: RECORD
  
  lock_table: `test`.`tx1`
  
  lock_index: PRIMARY
  
  lock_space: 460
  
  lock_page: 3
  
  lock_rec: 4
  
  lock_data: 3
  
  *************************** 2. row ***************************
  
  lock_id: 613962:460:3:4
  
  lock_trx_id: 613962
  
  lock_mode: X
  
  lock_type: RECORD
  
  lock_table: `test`.`tx1`
  
  lock_index: PRIMARY
  
  lock_space: 460
  
  lock_page: 3
  
  lock_rec: 4
  
  lock_data: 3
  
  2 rows in set, 1 warning (0.00 sec)
  
  ## 锁等待的对应关系
  
  mysql> select * from information_schema.innodb_lock_waits\G;
  
  *************************** 1. row ***************************
  
  requesting_trx_id: 613963
  
  requested_lock_id: 613963:460:3:4 #请求锁的锁ID
  
  blocking_trx_id: 613962 #当前拥有锁的事务ID
  
  blocking_lock_id: 613962:460:3:4
  
  1 row in set, 1 warning (0.00 sec)
  
  二、查看锁的情况
  
  mysql> show status like 'innodb_row_lock_%';
  
  +-------------------------------+--------+
  
  | Variable_name | Value |
  
  +-------------------------------+--------+
  
  | Innodb_row_lock_current_waits | 1 |
  
  | Innodb_row_lock_time | 479764 |
  
  | Innodb_row_lock_time_avg | 39980 |
  
  | Innodb_row_lock_time_max | 51021 |
  
  | Innodb_row_lock_waits | 12 |
  
  +-------------------------------+--------+
  
  5 rows in set (0.00 sec)
  
  解释如下:
  
  Innodb_row_lock_current_waits : 当前等待锁的数量
  
  Innodb_row_lock_time : 系统启动到现在,锁定的总时间长度
  
  Innodb_row_lock_time_avg : 每次平均锁定的时间
  
  Innodb_row_lock_time_max : 最长一次锁定时间
  
  Innodb_row_lock_waits : 系统启动到现在总共锁定的次数
  
  # 查询是否锁表
  
  mysql> show OPEN TABLES where In_use > 0;
  
  +----------+-------+--------+-------------+
  
  | Database | Table | In_use | Name_locked |
  
  +----------+-------+--------+-------------+
  
  | test | tx1 | 1 | 0 |
  
  +----------+-------+--------+-------------+
  
  1 row in set (0.00 sec)
  
  三、杀死进程
  
  # 1.查询进程
  
  mysql> show processlist\G # \G 结构旋转90度变成纵向
  
  *************************** 1. row ***************************
  
  Id: 138
  
  User: root
  
  Host: localhost:55106
  
  db: test
  
  Command: Query
  
  Time: 0
  
  State: starting
  
  Info: show processlist
  
  *************************** 2. row ***************************
  
  Id: 140
  
  User: root
  
  Host: localhost:56158
  
  db: test
  
  Command: Sleep
  
  Time: 145
  
  State:
  
  Info: NULL
  
  2 rows in set (0.00 sec)
  
  2 rows in set (0.00 sec)
  
  # 2.杀死对应进程ID
  
  mysql> kill 140;
  
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> show processlist\G
  
  *************************** 1. row ***************************
  
  <script src="https://www.zhenghongyule.com cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
  
  <link href="https://dasheng178.com maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
  
  <script src="https://www.yongshiyule178.com cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
  
  <style>
  
  div.item img{
  
  width:100%;
  
  }
  
  div#carousel-example-generic{
  
  width:80%;
  
  margin:0 auto;
  
  }
  
  </style>
  
  <div id="carousel-example-generic" class="carousel slide" data-ride="carousel">
  
  <!-- 轮播指标 -->
  
  <ol class="carousel-indicators">
  
  <li data-target="#carousel-example-generic"www.yinxionghui1.com data-slide-to="0" class="active"></li>
  
  <li data-target="#carousel-example-generic" www.yigouylpt2.cn/ data-slide-to="1"></li>
  
  <li data-target="#carousel-example-generic"www.zhongxinyul2.com data-slide-to="2"></li>
  
  <li data-target="#carousel-example-generic"www.xtd912.com data-slide-to="3"></li>
  
  </ol>
  
  <!-- 轮播的幻灯片项目 -->
  
  <div class="carousel-inner" role="listbox">
  
  <div class="item active">
  
  <img src="http://pic1.win4000.com/wallpaper/2019-02-21/5c6e434e8d2fb.jpg" >
  
  </div>
  
  <div class="item">
  
  <img src="http://pic1.win4000.com/wallpaper/2019-02-11/5c6137ee00320.jpg" >
  
  </div>
  
  <div class="item">
  
  <img src="http://pic1.win4000.com/wallpaper/2019-01-27/5c4d7aa191adb.jpg" >
  
  </div>
  
  <div class="item">
  
  <img src="http://pic1.win4000.com/wallpaper/2019-01-27/5c4d7a9f6030c.jpg" >
  
  </div>
  
  </div>
  
  Id: 138
  
  User: root
  
  Host: localhost:55106
  
  db: test
  
  Command: Query
  
  Time: 0
  
  State: starting
  
  Info: show processlist
  
  1 row in set (0.00 sec)
  
  四、SQL分析
  
  描述MySQL如何执行查询操作、以及MySQL成功返回结果集需要执行的行数。
  
  0. 1.EXPLAIN tbl_name 或 EXPLAIN [EXTENDED] SELECT select_options
  
  2.
  
  五、数据库的一些默认设置
  
  # 查看数据库默认存储引擎
  
  mysql> show engines;
  
  +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
  
  | Engine | Support | Comment | Transactions | XA | Savepoints |
  
  +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
  
  | InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
  
  | MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
  
  | MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
  
  | BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
  
  | MyISAM | YES | MyISAM storage engine | NO | NO | NO |
  
  | CSV | YES | CSV storage engine | NO | NO | NO |
  
  | ARCHIVE | YES | Archive storage engine | NO | NO | NO |
  
  | PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |
  
  | FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
  
  +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
  
  9 rows in set (0.00 sec)
  
  # 查看当前数据库默认隔离级别
  
  mysql> select @@global.tx_isolation;
  
  +-----------------------+
  
  | @@global.tx_isolation |
  
  +-----------------------+
  
  | REPEATABLE-READ |
  
  +-----------------------+
  
  1 row in set, 1 warning (0.00 sec)
  
  # 默认自动提交事务
  
  mysql> show global variables like 'autocommit';
  
  +---------------+-------+
  
  | Variable_name | Value |
  
  +---------------+-------+
  
  | autocommit | ON |
  
  +---------------+-------+
  
  1 row in set (0.00 sec)
  
  mysql> select @@global.autocommit;
  
  +---------------------+
  
  | @@global.autocommit |
  
  +---------------------+
  
  | 1 |
  
  +---------------------+
  
  1 row in set (0.00 sec)

查看Mysql正在执行的事务、锁、等待的更多相关文章

  1. mysql 查询正在执行的事务以及等待锁 常用的sql语句

    使用navicat测试学习: 首先使用set autocommit = 0;(取消自动提交,则当执行语句commit或者rollback执行提交事务或者回滚)   在打开一个执行update查询 正在 ...

  2. MySQL事务锁等待超时 Lock wait timeout exceeded; try restarting transaction

    工作中处理定时任务分发消息时出现的问题,在查找并解决问题的时候,将相关的问题博客收集整理,在此记录下,以便之后再遇到相同的问题,方便查阅. 问题场景 问题出现的场景: 在消息队列处理消息时,同一事务内 ...

  3. MySQL · 引擎特性 · InnoDB 事务锁简介

    https://yq.aliyun.com/articles/4270# zhaiwx_yinfeng 2016-02-02 19:00:43 浏览2194 评论0 mysql innodb lock ...

  4. 查看Mysql实时执行的Sql语句

    最近给客户开发了基于Asp.Net mvc5 +Mysql+EF的项目,但是在EF里无法看到Mysql执行的语句 之前也找到一些监控Mysql的软件但一直没有用起来,现在又遇到了问题即在EF里Mysa ...

  5. 查看mysql正在执行的SQL语句,使用profile分析SQL执行状态

    http://qq85609655.iteye.com/blog/2113960 1)我们先通过status命令查看Mysql运行状态 mysql> status; -------------- ...

  6. 查看MySQL最近执行的语句

    首先登入MySQL. Reading table information for completion of table and column names You can turn off this ...

  7. 查看MySQL正在执行的线程

    一.使用SQL语句查询正在执行的线程 SHOW PROCESSLIST; 二.使用kill 线程id就可以结束线程(引起数据变化的线程需特别小心) SHOW PROCESSLIST; +------+ ...

  8. 使用explain查看mysql查询执行计划

    explain语句: 字段解释: type:     all(全表扫描)     ref() possible_keys:     预测使用什么列做为索引 key:     实际使用的key     ...

  9. MySQL事务锁问题-Lock wait timeout exceeded

    转载:https://cloud.tencent.com/developer/article/1356959 问题现象:   接口响应时间超长,耗时几十秒才返回错误提示,后台日志中出现Lock wai ...

随机推荐

  1. 【UGUI】 (三)------- 背包系统(上)之简易单页背包系统及检索功能的实现

    背包系统,无论是游戏还是应用,都是常常见到的功能,其作用及重要性不用我多说,玩过游戏的朋友都应该明白. 在Unity中实现一个简易的背包系统其实并不是太过复杂的事.本文要实现的是一个带检索功能的背包系 ...

  2. MD5加密--项目案例

    在项目中最尝使用MD5这种非对称加密的就是用户信息登录了.下面我就以一个简单的登录案例来说明MD5的用法 首先来看几张图: 用户登录页:需要选择要登录的系统,同时输入用户的用户名和密码,验证码才能进入 ...

  3. Harbor 学习分享系列4 - Harbor常用功能实验

    前言 本文为Harbor技术分享系列的第4部分也是初级部分的完结篇,下个阶段作者将会进阶分享,更多详细的内容将会将会在文中介绍. 云盘链接 链接:https://pan.baidu.com/s/1PT ...

  4. hadoop最新稳定版本使用建议

    Apache Hadoop Apache版本衍化比较快,我给大家介绍一下过程 ApacheHadoop版本分为两代,我们将第一代Hadoop称为Hadoop 1.0,第二代Hadoop称为Hadoop ...

  5. GlusterFS分布式存储集群-1. 部署

    参考文档: Quick Start Guide:http://gluster.readthedocs.io/en/latest/Quick-Start-Guide/Quickstart/ Instal ...

  6. nodejs 搭建自己的简易缓存cache管理模块

    http://www.infoq.com/cn/articles/built-cache-management-module-in-nodejs/ 为什么要搭建自己的缓存管理模块? 这个问题其实也是在 ...

  7. nodejs 中 module.exports 和 exports 的区别

    1. module应该是require方法中,上下文中的对象 2. exports对象应该是上下文中引用module.exports的新对象 3. exports.a = xxx 会将修改更新到mod ...

  8. Python操作数据库之 MySQL

    Python操作数据库之MySQL 一.安装Python-MySQLdb模块 Python-MySQLdb是一个操作数据库的模块,Python 通过它对 mysql 数据实现各种操作. 如果要源码安装 ...

  9. lambda----jdk8重头戏

    简介(译者注:虽然看着很先进,其实Lambda表达式的本质只是一个"语法糖",由编译器推断并帮你转换包装为常规的代码,因此你可以使用更少的代码来实现同样的功能.本人建议不要乱用,因 ...

  10. TeamWork#3,Week5,Scrum Meeting 11.13

    最近我们根据之前发现的问题, 补充了相关知识,正在努力修复出现的问题,调整程序结构. 成员 已完成 待完成 彭林江 之前没有考虑到网站信息更新导致的程序可变性,正在调整爬虫程序结构 更换爬虫结构 郝倩 ...