测试mysql数据库死锁的sql语句
时间: 2023-09-15 17:15:25 浏览: 48
下面是一个测试MySQL数据库死锁的SQL语句:
```
-- 创建表
CREATE TABLE `test_table` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB;
-- 插入数据
INSERT INTO `test_table`(`name`) VALUES ('Alice'),('Bob');
-- 开启事务1
START TRANSACTION;
-- 查询数据并加锁
SELECT * FROM `test_table` WHERE `id`=1 FOR UPDATE;
-- 开启事务2
START TRANSACTION;
-- 查询数据并加锁
SELECT * FROM `test_table` WHERE `id`=2 FOR UPDATE;
-- 交叉更新数据
UPDATE `test_table` SET `name`='Bobby' WHERE `id`=2;
UPDATE `test_table` SET `name`='Alicia' WHERE `id`=1;
-- 提交事务2
COMMIT;
-- 提交事务1
COMMIT;
```
这个SQL语句创建了一个名为`test_table`的表,并在其中插入了两条数据。然后,它开启了两个事务,并在每个事务中查询并锁定表中的一条数据。随后,它在这两个事务中交叉更新了数据,并最终提交了这两个事务。
如果你同时运行两个该SQL语句的实例(可以在两个不同的MySQL客户端中运行),你可能会看到MySQL数据库死锁的情况。