Qual o mais performático?
Vamos fazer uma pequena análise sobre o assunto e o que faz cada uma das funcionalidades.
UNION
O comando UNION é usado para selecionar informações de duas tabelas, bem parecido com o JOIN. Porém quando usamos o UNION todas as colunas selecionadas precisam ser do mesmo tipo de dados nas duas tabelas. No comando UNION, apenas valores distintos são retornados.
UNION ALL
O UNION ALL é bem parecido com o UNION, exceto que o UNION ALL retorna todos os valores (valores duplicados).
A diferença entre o UNION e o UNION ALL é que o UNION ALL não elimina os valores duplicados, ao invés disso ele pega todos os valores de todas as tabelas ligadas e coloca no resultado que você especificou na sua query.
O comando UNION faz um SELECT DISTINCT nos resultados obtidos. Quando você sabe que todos os resultados são distintos, use o UNION ALL, para obter os resultados mais rápido.
Vou tentar explicar de uma forma mais “popular”: Digamos que eu tenho 2 baralhos de cartas e digo pra você, eu quero cartas dos dois baralhos que estão na mesa, mas eu não quero cartas repetidas, você evidentemente levaria mais tempo para separar essas cartas certo? Agora no UNION ALL eu digo o seguinte, pegue todas as cartas dos dois baralhos que estão na mesa e me traga tudo, independente de estarem repetidas ou não. Seria menos trabalhoso não é?
Abaixo eu vou incluir um exemplo demostrativo para vocês terem uma noção da diferenças dos custos para UNION e UNION ALL:
Script
/* Declarar a primeira tabela */ DECLARE @Tabela1 TABLE (CodVarchar VARCHAR(10)) INSERT INTO @Tabela1 SELECT 'A' UNION ALL SELECT 'B' UNION ALL SELECT 'C' UNION ALL SELECT 'D' UNION ALL SELECT 'E' /* Declarar a segunda tabela */ DECLARE @Tabela2 TABLE (CodVarchar VARCHAR(10)) INSERT INTO @Tabela2 SELECT 'A' UNION ALL SELECT 'B' UNION ALL SELECT 'C' /* Checando os dados */ /*SELECT * FROM @Tabela1 SELECT * FROM @Tabela2 */ /* UNION ALL */ SELECT * FROM @Tabela1 UNION SELECT * FROM @Tabela2 /* UNION */ SELECT * FROM @Tabela1 UNION ALL SELECT * FROM @Tabela2 GO
Na imagem abaixo podemos ver o plano de execução a diferença entre os dois comandos.
Wesley Mota
Latest posts by Wesley Mota (see all)
- Free Blackjack No Download: Appreciate Blackjack Anytime, Anywhere - novembro 25, 2024