Categories: DicasPerformance

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

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.

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)

Wesley Mota

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.

Share
Published by
Wesley Mota

Recent Posts

Free Blackjack No Download: Appreciate Blackjack Anytime, Anywhere

Blackjack, additionally known as twenty-one, is just one of one of the most popular gambling…

4 semanas ago

The Ultimate Guide to Gry Online Ruletka

If you are a fan of online gambling, then you must have come across gry…

1 mês ago

Discover the Adventures of Free Spins at Online Casino Sites

On the internet online casinos have transformed the betting industry, enabling players to vegas.hu online…

7 meses ago

Best Free Spins No Deposit

Casinos online offer free spins to draw new customers. These bonuses are usually very profitable,…

8 meses ago

Ideal Online Port Gambling Enterprises: An Overview to Locating the Perfect Pc Gaming Experience

In recent times, online casino sites have actually obtained enormous appeal among gamers, providing a…

8 meses ago

Best Online Casinos That Accept Bitcoin Down Payments

Bitcoin, the most preferred cryptocurrency worldwide, has reinvented lots of industries, including the on baixar…

8 meses ago