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:
Tabela de taxas:
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:
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:
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:
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: