A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 毛喆 初级黑马   /  2013-1-15 17:31  /  878 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我用的是MySQL 5.5.28

CREATE TABLE `t` (
`a` int(11) NOT NULL,
PRIMARY KEY (`a`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

# 会话A
mysql> select * from t;
+---+
| a |
+---+
| 1 |
| 2 |
| 4 |
+---+
3 rows in set (0.00 sec)

mysql> begin;
Query OK, 0 rows affected (0.05 sec)

mysql> select * from t where a < 4 for update;
+---+
| a |
+---+
| 1 |
| 2 |
+---+
2 rows in set (0.12 sec)
# 会话B
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t select 5;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
默认的是REPEATABLE-READ, 为什么insert id =5 会被block呢?按理说使用的Next-key Lock,a<4锁定的区间应该是(无穷小, 4],求指教。

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马