JOINS no SQL Server: tutorial com exemplos

Podemos recuperar dados de mais de uma tabela usando a instrução JOIN. Existem principalmente 4 tipos diferentes de JOINS no SQL Server. Aprenderemos todos os JOINS em Servidor SQL com exemplos:

  • INNER JOIN/junção simples
  • LEFT OUTER JOIN/LEFT JOIN
  • RIGHT OUTER JOIN/RIGHT JOIN
  • JUNÇÃO EXTERNA COMPLETA

INNER JOIN

Este tipo de JOIN do SQL Server retorna linhas de todas as tabelas nas quais a condição de junção é verdadeira. É necessária a seguinte sintaxe:

SELECT columns
FROM table_1 
INNER JOIN table_2
ON table_1.column = table_2.column;

Usaremos as duas tabelas a seguir para demonstrar isso:

Mesa de Alunos:

INNER JOIN

Tabela de taxas:

INNER JOIN

O comando a seguir demonstra um INNER JOIN no SQL Server com exemplo:

SELECT Students.admission, Students.firstName, Students.lastName, Fee.amount_paid
FROM Students
INNER JOIN Fee
ON Students.admission = Fee.admission

O comando retorna o seguinte:

INNER JOIN

Podemos informar os alunos que pagaram suas taxas. Utilizamos a coluna com valores comuns nas duas tabelas, que é a coluna de admissão.

JUNÇÃO EXTERNA ESQUERDA

Este tipo de junção retornará todas as linhas da tabela da esquerda mais os registros da tabela da direita com valores correspondentes. Por exemplo:

SELECT Students.admission, Students.firstName, Students.lastName, Fee.amount_paid
FROM Students
LEFT OUTER JOIN Fee
ON Students.admission = Fee.admission

O código retorna o seguinte:

JUNÇÃO EXTERNA ESQUERDA

Os registros sem valores correspondentes são substituídos por NULLs nas respectivas colunas.

DIREITO OUTER JOIN

Este tipo de junção retorna todas as linhas da tabela da direita e apenas aquelas com valores correspondentes na tabela da esquerda. Por exemplo:

SELECT Students.admission, Students.firstName, Students.lastName, Fee.amount_paid
FROM Students
RIGHT OUTER JOIN Fee
ON Students.admission = Fee.admission

A instrução para OUTER JOINS SQL server retorna o seguinte:

DIREITO OUTER JOIN

A razão para a saída acima é que todas as linhas da tabela Taxas estão disponíveis na tabela Alunos quando correspondidas na coluna admissão.

JUNÇÃO EXTERNA COMPLETA

Este tipo de junção retorna todas as linhas de ambas as tabelas com valores NULL onde a condição JOIN não é verdadeira. Por exemplo:

SELECT Students.admission, Students.firstName, Students.lastName, Fee.amount_paid
FROM Students
FULL OUTER JOIN Fee
ON Students.admission = Fee.admission

O código retorna o seguinte resultado para consultas FULL OUTER JOINS em SQL:

JUNÇÃO EXTERNA COMPLETA