Linux slogan
Visite também: Segurança Linux · BR-Linux.org · Dicas-L · Doode · NoticiasLinux · SoftwareLivre.org · UnderLinux



» Screenshot
» Login
Login:
Senha:

Se você ainda não possui uma conta, clique aqui.

Esqueci minha senha


Dica

Oracle: Diferença entre JOIN interno e externo
Linux user
Publicado por Robson Fernando Gomes em 28/01/2011

Login: magotico, 185400 pontos | Blog: http://maguscode.blogspot.com/
[ Hits: 3567 ]

Oracle: Diferença entre JOIN interno e externo

O objetivo desta dica é demonstrar a diferença entre o join interno e externo.

JOIN INTERNO (INNER JOIN)

O Join interno acontece quando desejamos pegar todas informações de duas tabelas distintas, ao contrário do join interno, este tipo de join pega somente as combinações válidas onde não existe valores nulos.

Sintaxe:

SELECT COLUNAS
   FROM TABELA1
INNER JOIN TABELA2
   ON TABELA1.ID=TABELA2.ID_TAB1

Exemplo: Existem duas tabelas distintas, CIDADE e FABRICANTE, farei um join interno:

SELECT * FROM fabricante INNER JOIN cidade ON fabricante.cidade_id = cidade.id

Existe uma maneira mais fácil e menor de fazer este tipo de join, como é exposto abaixo:

Sintaxe:

SELECT CAMPOS
   FROM TABELA1,TABELA2
   WHERE TABELA1.ID=TABELA2.ID_TAB2

Exemplo:

SELECT * FROM CIDADE,FABRICANTE WHERE CIDADE.ID=FABRICANTE.CIDADE_ID

JOIN EXTERNO (OUTER JOIN)

O Join externo acontece quando desejamos pegar todas informações de duas tabelas distintas. Caso durante a junção da tabelas hajam campos que não tenham valores (null), esses campos serão preenchidos com null. Cabe salientar que é possível escolher qual tabela favorecer neste tipo de join, pode ser a tabela da direita ou da esquerda, como pode ser visto abaixo:

Sintaxe:

SELECT COLUNAS FROM TABELA1
RIGHT/LEFT OUTER JOIN TABELA2 ON TABELA1.ID=TABELA2.ID_TAB1

Cabe salientar que no RIGHT/LEFT é utilizado só uma das opções, RIGHT ou LEFT.

Exemplo: Existem duas tabelas distintas, CIDADE e FABRICANTE, farei um join externo para direita (right) das mesmas:

SELECT * FROM fabricante RIGHT OUTER JOIN cidade ON fabricante.cidade_id = cidade.id

Caso você esteja utilizando o Oracle, o outer join pode ser feito utilizando a notação (+) ao lado tabela que você deseja que seja favorecida:

Sintaxe:

SELECT CAMPOS
   FROM TABELA1,TABELA2
   WHERE TABELA1.ID(+)=TABELA2.ID_TAB2

Exemplo:

SELECT * FROM CIDADE,FABRICANTE WHERE CIDADE.ID(+)=FABRICANTE.CIDADE_ID

Bibliografia:

Outras dicas deste autor

Leitura recomendada
   Dica Linux recomendada IPPL - IP Protocols Logger
   Dica Linux recomendada Servidor VMware 2.0.2 em Debian Squeeze 6.0.0 (64 bits)
   Dica Linux recomendada Virtualização - VirtualBox em modo texto e acesso remoto
   Dica Linux recomendada Iniciando na linguagem Perl
   Dica Linux recomendada Habilitando mais de 4 placas multi-seriais em kernel 2.6.13 ou superior

Comentários
Nenhum comentário foi encontrado.

Contribuir com comentário


  
Para executar esta ação você precisa estar logado no site, caso contrário, tudo o que for digitado será perdido.
Responsável pelo site: Fábio Berbert de Paula - Conteúdo distribuído sob licença GNU FDL
Site hospedado por:

Viva o Linux

A maior comunidade Linux da América Latina! Artigos, dicas, tutoriais, fórum, scripts e muito mais. Ideal para quem busca auto-ajuda em Linux.