Mysql – Eliminar datos de dos tablas a la vez

Pongamos un ejemplo claro para mostrar qué queremos hacer. Por un lado, tenemos en una tabla llamada Facturas los datos de la factura. Por otro lado, tenemos la tabla Facturas_lineas dónde almacenamos las líneas de las facturas. Al eliminar una factura debe eliminarse las líneas correspondientes…

Lo haremos de la siguiente manera:

1
2
3
DELETE a1, a2 FROM
Facturas AS fac JOIN Facturas_lineas AS lin
WHERE lin.factura_ID=fac.Id AND fac.Id=3241

De esta manera, estamos eliminando los registros de facturas y de facturals lineas que cumplan la condición que la Id sea la 3241.

Y si, esto es solo un ejemplo. Si en la base datos hubiéramos relacionado correctamente las dos tablas con claves foráneas (ON DELETE CASCADE), la eliminación se haría de forma automática. Sólo es un ejemplo para eliminar en una sola consulta dos registros de dos tablas diferentes.

Atentos, porque toda eliminación son críticas. Haced copia de seguridad antes, y nosotros no nos hacemos cargo de cómo utilizáis el código que os mostramos, lo hacéis bajo vuestra responsabilidad.

Artículos relacionados

Mysql – UNION ALL y GROUP BY o ORDER BY Cuando en MySql se utiliza el UNION ALL, estamos uniendo los resultados de varias consultas. Para ello, debe cumplirse varias condiciones, entre la qu...
Mysql – Importar una base de datos desde con... Cuando manejamos grandes cantidades de datos en MySql, se hace difícil importar base de datos con phpMyAdmin (herramienta online que permite trabajar ...
Mysql – Unir los resultados de dos consultar... En muchas ocasiones nos puede interesar unir el resultado de dos consultas. Ya sabemos que para unirlos, los resultados de las consultas deben tener e...
MySql – Eliminar registro saltando claves fo... En ocasiones nos enfrentamos a casos puntuales en los que valoras si arriesgarte o no. Una de ellas es la eliminación de registros en un motor de base...

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

*