Dica T-SQL: Deletando registros com FK


Muitas vezes você já deve ter necessitado apagar tabelas em ambiente de desenvolvimento, e até porque não em produção 🙂

Ai você pensa, vou mandar logo um TRUNCATE TABLE, mas infelizmente não é possível fazer um TRUNCATE TABLE em uma tabela com FK, ai você pensa “vai dá uma preguiça dropar e recriar todas FK”. entãoE você logo pensa, “DELETE na cabeça”, mas se você vai deletar você tem que analisar o que deletar antes do que, por exemplo, você não pode deletar um cliente se existe uma venda associada a ele.

Resumindo, se você precisar limpar umas tabelas sem se preocupar muito use o script abaixo, ele irá desabilitar as constraints e reabilitar após alterações


EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'

--DELETA O QUE FOR NECESSÁRIO

EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'

Advertisements

One thought on “Dica T-SQL: Deletando registros com FK

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Google photo

You are commenting using your Google account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s