sql >> Base de Datos >  >> RDS >> Mysql

Cómo causar interbloqueo en MySQL

Hay numerosas publicaciones para esto mediante el uso de dos sesiones.

https://dba.stackexchange.com/questions/309/code -para-simular-punto muerto

http://www.xaprb.com/blog/2006/08/08/how-to-deliberately-cause-a-deadlock-in-mysql/

Método copiado del segundo artículo anterior

Primero, elija un nombre de tabla no utilizado. Usaré test.innodb_deadlock_maker. Estas son las sentencias que necesita ejecutar:

create table test.innodb_deadlock_maker(a int primary key) engine=innodb;
insert into test.innodb_deadlock_maker(a) values(0), (1);

Ahora la tabla y sus datos están configurados. A continuación, ejecute lo siguiente en dos conexiones diferentes:

-- conexión 0

set transaction isolation level serializable;
start transaction;
select * from test.innodb_deadlock_maker where a = 0;
update test.innodb_deadlock_maker set a = 0 where a <> 0;

-- conexión 1

set transaction isolation level serializable;
start transaction;
select * from test.innodb_deadlock_maker where a = 1;
update test.innodb_deadlock_maker set a = 1 where a <> 1;