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.
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…