Cuando necesitamos eliminar tablas en SQL Server puede ser que el sistema no nos lo permita si estas hacen referencia a una restricción FOREIGN KEY. Obligándolos primero a eliminar las restricciones antes de continuar. Algo que se puede conseguir de forma manual mediante la creación de un script, como automática gracias a la herramienta de SQL Server Management Studio. Veamos cómo se puede conseguir borrar tablas con dependencias en SQL Server usando ambos métodos.
Borrado manual de las dependencias
El borrado manual de las tablas con dependencias requiere seguir unos pasos. En primer lugar, es necesario saber cuales son las dependencias, algo que se puede conseguir con la siguiente consulta
SELECT * FROM sys.foreign_keys WHERE referenced_object_id = object_id('TABLE_NAME')
En donde TABLE_NAME
es el nombre de la tabla a borrar. Si el resultado de la consulta no está vacío existe una o más dependencias que se pueden borrar con la siguiente consulta.
SELECT 'ALTER TABLE [' + OBJECT_SCHEMA_NAME(parent_object_id) + '].[' + OBJECT_NAME(parent_object_id) + '] DROP CONSTRAINT [' + name + ']' FROM sys.foreign_keys WHERE referenced_object_id = object_id('TABLE_NAME')
Una vez ejecutada esta consuela ya se puede borrar la tabla mediante el comando
DROP TABLE TABLE_NAME
Borrar tablas con dependencias con Management Studio
Si solamente hay que borrar una tabla el proceso anterior no es complicado, pero sí cuando hay que repetirlo con decenas de tablas. En estos casos se puede recurrir al generador de scripts de SQL Server Management Studio. Una herramienta a la que se puede acceder pulsando sobre el motor derecho de la base de datos y seleccionado Tasks -> Generate Scripts
En el asistente que aparece seleccionamos las tablas de la base de datos que deseamos eliminar y pulsamos en Next.
A continuación, seleccionamos la opción "Open in a new query Window" y pulsamos sobre el botón Advanced.
En la ventana que aparece al pulsar sobre Advance buscamos la opción "Script DROP and CREATE" y seleccionamos la opción "Script DROP".
Al pulsar sobre OK se sale de esta ventana y se vuelve a la anterior donde se puede pulsar sobre Next. Apreciando una ventana con un resumen de los pasos que hemos dado, volviendo a pulsar sobre Next. En este punto se creará un script con los pasos necesarios para eliminar las tablas seleccionadas. Al pulsar sobre Finish nos aparecerá un script que podemos ejecutar para borrar todas las tablas seleccionadas.
Conclusiones
En este paso hemos visto dos métodos con los que es posible borrar tablas con dependencias en SQL Server. El proceso manual no es complicado, pero el proceso automático nos permite ir más rápido cuando el número de tablas es mayor.
Imagen de Do Exploit en Pixabay