ITPub博客

首页 > 数据库 > MySQL > mysql snapshot read快照读及current read当前读与锁lock之一

mysql snapshot read快照读及current read当前读与锁lock之一

原创 MySQL 作者:wisdomone1 时间:2019-11-29 18:36:51 0 删除 编辑

前言

       mysql读操作分为2种类型:snapshot read及current read,前者基于mysql mvcc实现,读取数据块是undo block,后者是基于当前数据块。这2种不同的读取类型与锁的关系是什么,本文作一点儿简要的记录。

联系方式

  • 微信公众号

  • 微信

目录

snapshot read是否加锁

  snapshot read由于操作非当前数据块,不会加锁


current read加锁2种类型

  •  x   --排它锁

  •  s   --共享锁


current read几种操作场景

查询current read不同操作场景持锁语句

(注:关注列lock_mode)

mysql> select * from information_schema.innodb_locks;
+-------------------------+-----------------+-----------+-----------+------------------+-----------------+------------+-----------+----------+----------------+
| lock_id                 | lock_trx_id     | lock_mode | lock_type | lock_table       | lock_index      | lock_space | lock_page | lock_rec | lock_data      |
+-------------------------+-----------------+-----------+-----------+------------------+-----------------+------------+-----------+----------+----------------+
| 11909:473:3:2           | 11909           | X         | RECORD    | `zxydb`.`t_read` | GEN_CLUST_INDEX |        473 |         3 |        2 | 0x00000836F561 |
| 421207096970864:473:3:2 | 421207096970864 | S         | RECORD    | `zxydb`.`t_read` | GEN_CLUST_INDEX |        473 |         3 |        2 | 0x00000836F561 |
+-------------------------+-----------------+-----------+-----------+------------------+-----------------+------------+-----------+----------+----------------+
2 rows in set, 1 warning (0.00 sec)


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9240380/viewspace-2666289/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
提供针对oracle初学者及进阶的数据库培训,欢迎大家咨询: 微信: wisdomone 微信公众号: lovedb 工作经历: 中国普天 北京科蓝 北京云和恩墨 北京神州新桥

注册时间:2008-04-04

  • 博文量
    2189
  • 访问量
    11965367