Saiba qual a diferença entre uma CTE e uma tabela temporária.
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:
- São indexáveis (mas podem usar índices existentes em objetos referenciados).
- Não podem utilizar constraints.
- São essencialmente descartáveis.
- Persiste apenas até a próxima consulta seja executada.
- Pode ser recursivo.
- Não tem estatísticas dedicadas (confie em estatísticas nos objetos subjacentes).
Tabelas temporárias:
- São tabelas materializadas que existem em tempdb.
- Podem ser indexadas.
- Podem ter constraints.
- Persiste durante o tempo de vida da conexão atual.
- Podem ser referenciadas em outras consultas e procedures.
- Tem estatísticas dedicadas geradas pela engine do SQL Server.
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.
Wesley Mota
Latest posts by Wesley Mota (see all)
- The Ultimate Guide to Gry Online Ruletka - novembro 14, 2024