首页 / MYSQL / MYSQL的伪行级锁_MySQL
MYSQL的伪行级锁_MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MYSQL的伪行级锁_MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3399字,纯文字阅读大概需要5分钟。
内容图文
![MYSQL的伪行级锁_MySQL](/upload/InfoBanner/zyjiaocheng/574/d742883e806e47d3b269398a0491579a.jpg)
MYSQL的伪行级锁 之前一直以为mysql的innodb引擎所支持的行级锁和oracle,postgresql是一样的,是对数据行上加锁。但其实是不一样的,理解不一样,对mysql的锁机制就容易产生误解。innodb的行级锁实际上是基于索引项来锁定的。以下是验证测试过程 一.数据准备mysql> use test;Database changedmysql> show create table t_kenyon /G*************************** 1. row *************************** Table: t_kenyonCreate Table: CREATE TABLE `t_kenyon` ( `id` int(11) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec) mysql> set autocommit = 0;Query OK, 0 rows affected (0.00 sec) mysql> show variables like '%autocommit%';+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | OFF |+---------------+-------+1 row in set (0.00 sec) mysql> select * from t_kenyon;+------+| id |+------+| 1 || 123 || 789 || 345 || 78 || 78 |+------+6 rows in set (0.00 sec)以上是测试表t_kenyon,设置提交方式为手动提交. 二.过程(开启两个session,分别设置autocommit=off) 1.session one updatemysql> update t_kenyon set id = 999 where id = 1;Query OK, 1 row affected (0.04 sec)Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from t_kenyon;+------+| id |+------+| 999 || 123 || 789 || 345 || 78 || 78 |+------+6 rows in set (0.00 sec)2.session two updatemysql> show variables like 'autocommit';+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | OFF |+---------------+-------+1 row in set (0.00 sec) mysql> select * from t_kenyon;+------+| id |+------+| 1 || 123 || 789 || 345 || 78 || 78 |+------+6 rows in set (0.00 sec) mysql> update t_kenyon set id = 88888 where id = 345;第二个session更新的值是345,但是也一直被阻塞,直到session1被rollback或者commit,如果session1未做回滚或者提交,session2中的该阻塞在超出mysql的锁时间限制时自动回滚,该参数为innodb_lock_wait_timeout,默认值50秒 现象如下ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction加索引后的测试 3.session one update mysql> create index ind_kenyon on t_kenyon(id);Query OK, 0 rows affected (28.58 sec)Records: 0 Duplicates: 0 Warnings: 0 mysql> update t_kenyon set id = 999 where id = 1;Query OK, 1 row affected (0.03 sec)Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from t_kenyon;+------+| id |+------+| 78 || 78 || 123 || 345 || 789 || 999 |+------+6 rows in set (0.00 sec)4.session two update mysql> select * from t_kenyon;+------+| id |+------+| 1 || 78 || 78 || 123 || 345 || 789 |+------+6 rows in set (0.00 sec) mysql> update t_kenyon set id = 7777 where id = 345;Query OK, 1 row affected (0.03 sec)Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from t_kenyon;+------+| id |+------+| 1 || 78 || 78 || 123 || 789 || 7777 |+------+6 rows in set (0.00 sec)执行计划mysql> explain select * from t_kenyon where id = 345 /G*************************** 1. row *************************** id: 1 select_type: SIMPLE table: t_kenyon type: refpossible_keys: ind_kenyon key: ind_kenyon key_len: 5 ref: const rows: 1 Extra: Using where; Using index1 row in set (0.00 sec)可以看到加了索引后,不同的数据更新并没有被阻塞,实现了真正意义上行锁 三.行级锁的扩展限制 参考:http:///database/201208/145888.html 作者 kenyon bitsCN.com
内容总结
以上是互联网集市为您收集整理的MYSQL的伪行级锁_MySQL全部内容,希望文章能够帮你解决MYSQL的伪行级锁_MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】