Como criar autojunções manualmente (Visual Database Tools)
A autojunção de uma tabela pode ser feita, mesmo se a tabela não tiver uma relação reflexiva no banco de dados. Por exemplo, você pode usar uma autojunção para encontrar pares de autores que moram na mesma cidade.
Como com qualquer junção, uma autojunção requer pelo menos duas tabelas. A diferença é que, em vez de acrescentar uma segunda tabela à consulta, você adicionar uma segunda instância da mesma tabela. Dessa forma, você pode comparar uma coluna na primeira instância da tabela para a mesma coluna na segunda instância, o que permite comparar os valores em uma coluna entre si. O Designer de Consulta e Exibição atribui um alias à segunda instância da tabela.
Por exemplo, se você estiver criando uma autojunção para encontrar todos os pares de autores em Berkeley, você comparará a coluna city na primeira instância da tabela com a coluna city na segunda instância. A consulta resultante pode ter a seguinte aparência:
SELECT
authors.au_fname,
authors.au_lname,
authors1.au_fname AS Expr2,
authors1.au_lname AS Expr3
FROM
authors
INNER JOIN
authors authors1
ON authors.city
= authors1.city
WHERE
authors.city = 'Berkeley'
A criação de uma autojunção normalmente requer várias condições de junção. Para entender o porquê, considere o resultado da consulta anterior:
Cheryl Carson Cheryl Carson
Abraham Bennet Abraham Bennet
Cheryl Carson Abraham Bennet
Abraham Bennet Cheryl Carson
A primeira linha é inútil; indica que Cheryl Carson mora na mesma cidade de Cheryl Carson. A segunda linha é igualmente inútil. Para eliminar esses dados inúteis, você adiciona outra condição que retém somente as linhas de resultado onde os nomes de dois autores descrevem autores diferentes. A consulta resultante pode ter a seguinte aparência:
SELECT
authors.au_fname,
authors.au_lname,
authors1.au_fname AS Expr2,
authors1.au_lname AS Expr3
FROM
authors
INNER JOIN
authors authors1
ON authors.city
= authors1.city
AND authors.au_id
<> authors1.au_id
WHERE
authors.city = 'Berkeley'
O conjunto de resultados é aprimorado.
Cheryl Carson Abraham Bennet
Abraham Bennet Cheryl Carson
Mas as duas linhas de resultado são redundantes. A primeira diz que Carson mora na mesma cidade de Bennet, e a segunda diz que Bennet mora na mesma cidade de Carson. Para eliminar essa redundância, você pode alterar a segunda condição de junção de “não igual” para “menor que”. A consulta resultante pode ter a seguinte aparência:
SELECT
authors.au_fname,
authors.au_lname,
authors1.au_fname AS Expr2,
authors1.au_lname AS Expr3
FROM
authors
INNER JOIN
authors authors1
ON authors.city
= authors1.city
AND authors.au_id
< authors1.au_id
WHERE
authors.city = 'Berkeley'
E o conjunto de resultados tem a seguinte aparência:
Cheryl Carson Abraham Bennet
Para criar uma autojunção manualmente
Adicione ao painel Diagrama a tabela ou o objeto com valor de tabela com os quais você deseja trabalhar.
Adicione a mesma tabela novamente, de forma que o painel Diagrama exiba a mesma tabela ou o mesmo objeto com valor de tabela duas vezes no painel Diagrama.
O Designer de Consulta e Exibição atribui um alias à segunda instância adicionando um número seqüencial ao nome da tabela. Além disso, o Designer de Consulta e Exibição cria uma linha de junção entre as duas ocorrências da tabela ou do objeto com valor de tabela dentro do painel Diagrama.
Clique com o botão direito do mouse na linha de junção e escolha Propriedades no menu de atalho.
Na janela Propriedades, clique em Condição e Tipo de Junção e clique nas reticências (...) à direita da propriedade.
Na caixa de diálogo Junção altere o operador de comparação entre as chaves primárias conforme requerido. Por exemplo, você pode alterar o operador para menor que (<).
Crie a condição de junção adicional (por exemplo, authors.zip = authors1.zip) arrastando o nome da coluna de junção primária na primeira ocorrência da tabela ou objeto com valor de tabela, soltando na coluna correspondente na segunda ocorrência.
Especifique outras opções para a consulta, como colunas de saída, critérios de pesquisa e ordem de classificação.
Consulte também