让我用一个 SQL 示例来开始我的问题。
这是表设置:
- 创建表
x
and y
. With y.x
指的是x.id
.
- 插入一行到
x
(id=1).
START TRANSACTION;
CREATE TABLE `x` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`value` INT(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB;
CREATE TABLE `y` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`x_id` INT(11) NOT NULL,
`value` INT(11) NOT NULL,
PRIMARY KEY (`id`),
CONSTRAINT `fk_x` FOREIGN KEY (`x_id`)
REFERENCES `x` (`id`)
) ENGINE=INNODB;
INSERT INTO x values (1,123456);
COMMIT;
现在启动一个事务 (Trx A) 来更新中的行x
.
START TRANSACTION;
UPDATE x SET value=value+1 WHERE id = 1;
在提交之前,我启动另一个事务 (Trx B) 来插入一行y
.
START TRANSACTION;
INSERT INTO y VALUES (null,1,123456);
---- HANGED ----
-- Until Trx A is committed or rolled-back, the Trx B is hanged here.
问题是 - Trx B 届时是否会被绞死?为什么以及有什么方法可以解决这个问题?
这已经在 MySQL 5.7.21、Percona 5.7.21、MariaDB 10.2.14 上进行了测试