82 - Borrar registros en cascada (delete - join) |
Tenemos la tabla "libros" en la cual almacenamos los datos de los libros de nuestra biblioteca y la tabla "editoriales" que almacena el nombre de las distintas editoriales y sus códigos.
La tabla "libros" tiene la siguiente estructura:
-codigo: int unsigned auto_increment, -titulo: varchar(30), -autor: varchar(30), -codigoeditorial: tinyint unsigned, -clave primaria: codigo.
La tabla "editoriales" tiene esta estructura:
-codigo: tinyint unsigned auto_increment, -nombre: varchar(20), -clave primaria: codigo.
Ambas tablas contienen registros.
La librería ya no trabaja con la editorial "Emece", entonces quiere eliminar dicha editorial de la tabla "editoriales" y todos los libros de "libros" de esta editorial. Podemos hacerlo en 2 pasos:
1º paso: buscar el código de la editorial "Emece" y almacenarlo en una variable:
select @valor:= codigo from editoriales where nombre='Emece';
2º paso: eliminar dicha editorial de la tabla "editoriales":
delete editoriales where codigo=@valor;
3º paso: eliminar todos los libros cuyo código de editorial sea igual a la variable:
delete libros where codigoeditorial=@valor;O podemos hacerlo en una sola consulta:
delete libros,editoriales from libros join editoriales on libros.codigoeditorial=editoriales.codigo where editoriales.nombre='Emece';
La sentencia anterior elimina de la tabla "editoriales" la editorial "Emece" y de la tabla "libros" todos los registros con código de editorial correspondiente a "Emece".
Es decir, podemos realizar la eliminación de registros de varias tablas (en cascada) empleando "delete" junto al nombre de las tablas de las cuales queremos eliminar registros y luego del correspondiente "join" colocar la condición "where" que afecte a los registros a eliminar.