Herramientas

Borrar tablas con dependencias en SQL Server

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

Acceso a la herramienta de generación se scripts de SQL Server Management Studio

En el asistente que aparece seleccionamos las tablas de la base de datos que deseamos eliminar y pulsamos en Next.

Seleccionado las tablas a usar en el generación se scripts de SQL Server Management Studio

A continuación, seleccionamos la opción “Open in a new query Window” y pulsamos sobre el botón Advanced.

Especificando dónde se guardarán los scripts generados con el asistente.

En la ventana que aparece al pulsar sobre Advance buscamos la opción “Script DROP and CREATE” y seleccionamos la opción “Script DROP”.

Seleccionar la opción para la creación de un script de borrado

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

¿Te ha parecido de utilidad el contenido?

Daniel Rodríguez

Share
Published by
Daniel Rodríguez

Recent Posts

Analytics Lane lanza ScoreFlow, un SaaS para construir y desplegar scorecards de crédito

En Analytics Lane seguimos evolucionando nuestras herramientas y damos un paso más con el lanzamiento…

4 días ago

DBSCAN y la selección de ε: teoría, intuición y aplicación práctica

Cuando hablamos de clustering, lo primero que viene a la mente suele ser k-means. Pero…

5 días ago

El bestiario de los indicadores económicos absurdos: El zoo patrio

Cualquier país desarrollado tiene sus propios indicadores folclóricos. España, por motivos que tienen mucho que…

1 semana ago

Por qué el banco te ofrece un 3% TAE y no es lo que parece

Entras a la web de tu banco. En la página principal, un banner llamativo: “Depósito…

2 semanas ago

Analytics Lane lanza la versión 1.3 del laboratorio con nuevas herramientas de evaluación de modelos y utilidades prácticas

Seguimos ampliando el laboratorio de Analytics Lane con el lanzamiento de la versión 1.3, disponible…

2 semanas ago

This website uses cookies.