SQL Server Performance

SQL Server – UNION vs UNION ALL – Qual é mais performático?

SQL Server Performance

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.

UNION VS UNION ALL

SQL Server – UNION vs UNION ALL – Qual é mais performático?
The following two tabs change content below.

Wesley Mota

DBA SQL Server
Profissional graduado em Banco de Dados e Sistemas de Informação com mais de 7 anos de experiência em empresas de software. Certificado MCSA Microsoft SQL Server possui intensa vivência em administração de banco de dados, Tunning, Performance SQL Server, levantamento de melhorias e monitoramento de banco de dados e servidores SQL Server. Consultoria SQL Server em diversos clientes no Brasil e ao redor do mundo. Escritor no blog dbasqlserverbr.com.br/blog. Onde compartilha conhecimento, experiências e dicas de performance para DBAs SQL Server. Conhecimentos em Oracle e ambientes de alta disponibilidade. Desenvolvimento de softwares web e mobile.Gerenciamento de equipe e projetos.

Latest posts by Wesley Mota (see all)