Recentemente me perguntaram qual a diferença entre uma CTE e uma tabela temporária. Para quem não sabe CTE é “Common Table Expression”, que significa expressão de tabela comum.
Certo, mas na prática, o que é uma e o que é outra?
Vamos lá, abaixo mostrarei a vocês os script de criação de ambas:
CTE:
WITH cte (Coluna1, Coluna2, Coluna3)
AS
(
SELECT Coluna1, Coluna2, Coluna3
FROM AlgumaTabela
)
SELECT * FROM cte
Tabela temporária:
SELECT Coluna1, Coluna2, Coluna3 INTO #tabelaTemporaria FROM AlgumaTabela SELECT * FROM #tabelaTemporaria
Em resumo vou citar abaixo quais são as diferenças.
CTE:
Tabelas temporárias:
Usando uma ou outra em quais ocasiões as utilidades são bem diferentes. Se você tiver um conjunto de resultados muito grande, ou precisar consultá-lo mais de uma vez, coloque-o em uma tabela #temp. Se ele precisa ser recursivo e descartável, ou é apenas para simplificar algo logicamente, um CTE é melhor opção.
Além disso uma CTE não deve ser utilizada para performance. Você quase não terá ganhos usando uma CTE por se tratar de uma view descartável, você pode utilizar para outras funcionalidades, mas para performance não é recomendado.
Utforska Topplista: Casinon utan licens med flest Megaways-slotsDet är ingen hemlighet att Megaways-slots har blivit…
ContentCultivo del pimiento¿Cómo beneficia la salud el pimentón ahumado?Enfermedades causadas por bacterias y virusPimentón de…
Content¿Cuáles son los mejores Nuevos Juegos gratuitos online?Qué es Poki? Ofrecemos acceso instantáneo a todos…
ContentErzählen Sie Ihre Geschichte: von Kampanien bis ins Herz Brasiliens, die Geschichte der Familie LandriEl…
ContentPrefeitura anuncia novo polo no Parque Eduardo Campos, no Pina, e espalha shows pela cidadeMarilia…
ContentStadtrundgänge Die Universitätsstadt Tübingen sucht seeger tübingen juwelier regelmäßig Verwaltungskräfte in verschiedenen Organisationseinheiten. Die Universitätsstadt…