Diego,

O select abaixo funcionou perfeitamente aqui no oracle 10g.

 SELECT
ROOT.JOGOS.GOLS_TIME1,
ROOT.JOGOS.GOLTS_TIME2,
time_1.NOME AS TIME1,
time_2.NOME AS TIME2,
FROM
ROOT.JOGOS
INNER JOIN ROOT.TIMES1 AS time_1 ON (time_1.ID_TIMES = ROOT.JOGOS.ID_TIME1)
INNER JOIN ROOT.TIMES2 AS time_2 ON (time_2.ID_TIMES = ROOT.JOGOS.ID_TIME2)

Em 2 de dezembro de 2010 13:30, Diego Feijó <[email protected]> escreveu:

> Bruno não são 2 tabelas de times como você colocou times1 e times2 é
> uma tabela chamada times. Mesmo alterando na segunda para "as time2" o
> erro persiste.
>
> Parece ser simples mas é bem chatinho de resolver, como falei a única
> solução que encontrei é com sub-select.
>
>
> On 2 dez, 13:26, Bruno Soares <[email protected]> wrote:
> > ROOT.TIMES1.NOME AS TIME1,
> >
> > > ROOT.TIMES2.NOME AS TIME1,
> >
> > ai está o erro
> >
> > Coluna com o mesmo nome
> >
> > 2010/12/2 Diego Feijó <[email protected]>
>  >
> >
> >
> > > Clayto, dessa forma já tentei e o oracle retorna um erro. ORA-00918:
> > > coluna definida de maneira ambígua
> >
> > > On 2 dez, 13:08, Clayton <[email protected]> wrote:
> > > > SELECT
> > > >  ROOT.JOGOS.GOLS_TIME1,
> > > >  ROOT.JOGOS.GOLTS_TIME2,
> > > >  ROOT.TIMES1.NOME AS TIME1,
> > > > ROOT.TIMES2.NOME AS TIME1,
> > > > FROM
> > > >  ROOT.JOGOS
> > > >  INNER JOIN ROOT.TIMES1 ON (ROOT.TIMES1.ID_TIMES =
> ROOT.JOGOS.ID_TIME1)
> > > > INNER JOIN ROOT.TIMES2 ON (ROOT.TIMES2.ID_TIMES =
> ROOT.JOGOS.ID_TIME2)
> >
> > > > Em 2 de dezembro de 2010 11:29, bruno bg <[email protected]>
> escreveu:
> >
> > > > > apesar dessa lista não ser de SQL, vc poderia colocar OFF-TOPIC.
> >
> > > > > então.
> > > > > no inner join vc pode fazer dois INNER JOIN com as tabelas de TIME
> > > > > e no final fazer um GROUP BY.
> >
> > > > > abraço
> > > > > --
> > > > > ****************************************************
> > > > >www.brunobg.com
> > > > > [email protected]  (MSN & Skype)
> > > > > blogflex.brunobg.com
> > > > > @brunogrohs
> > > > > (21) 9913-2397
> >
> > > > > Em 2 de dezembro de 2010 09:04, Diego Feijó <[email protected]>
> > > escreveu:
> >
> > > > > Bom dia Pessoal,
> > > > >> ontem realizei minha prova de grau2 sobre banco de dados, porém
> tinha
> > > > >> uma questão que está me deixando encucado, vou descrever ela aqui
> e
> > > > >> gostaria de ver quais as soluções que vocês dariam.
> >
> > > > >> Vamos lá.
> >
> > > > >> Tenho 2 tabelas Times e Jogos. Na tabela de times tenho os
> seguintes
> > > > >> fields TIMES(id_time,nome). Na tabela de jogos tenho
> JOGOS(id_jogo,
> > > > >> idtime1, idtime2, gols_time1, gols_time2).
> >
> > > > >> Na tabela de jogos tenho 2 relacionamentos para a tabela de times.
> Na
> > > > >> prova utilizei um sub-select para fazer o segundo relacionamento,
> > > > >> conforme abaixo. Neste caso ele me traz 1 registro com os 2 times
> e os
> > > > >> gols de cada time, tudo certinho.
> >
> > > > >> SELECT
> > > > >>  ROOT.JOGOS.GOLS_TIME1,
> > > > >>  ROOT.JOGOS.GOLTS_TIME2,
> > > > >>  ROOT.TIMES.NOME AS TIME1,
> > > > >>  (SELECT ROOT.TIMES.NOME FROM JOGOS INNER JOIN ROOT.TIMES ON
> > > > >> (ROOT.TIMES.ID_TIMES = JOGOS.ID_TIME2)) AS TIME2
> > > > >> FROM
> > > > >>  ROOT.JOGOS
> > > > >>  INNER JOIN ROOT.TIMES ON (ROOT.TIMES.ID_TIMES =
> ROOT.JOGOS.ID_TIME1)
> >
> > > > >> Porém na hora de entregar a prova ao professor ele me disse que
> não
> > > > >> era necessário utilizar o sub-select, somente com inner join
> > > > >> funcionaria.
> > > > >> Cheguei agora no trampo e fiz o teste, somente com inner join como
> ele
> > > > >> falou, porém me traz 2 registros com os 2 times mas com os gols
> > > > >> duplicados, ficando errado conforme enunciado da prova.
> >
> > > > >> Pergunto a vocês teria outra forma de fazer essa questão?
> >
> > > > >> Obrigado desde já
> > > > >> Diego Feijó.
> >
> > > > >> --
> > > > >> Você recebeu esta mensagem porque está inscrito na lista "flexdev"
> > > > >> Para enviar uma mensagem, envie um e-mail para
> > > [email protected]
> > > > >> Para sair da lista, envie um email em branco para
> > > > >> [email protected]
> > > > >> Mais opções estão disponíveis emhttp://
> > > groups.google.com/group/flexdev
> >
> > > > > --
> > > > > Você recebeu esta mensagem porque está inscrito na lista "flexdev"
> > > > > Para enviar uma mensagem, envie um e-mail para
> > > [email protected]
> > > > > Para sair da lista, envie um email em branco para
> > > > > [email protected]
> > > > > Mais opções estão disponíveis emhttp://
> groups.google.com/group/flexdev
> >
> > > > --
> > > > Clayton Marques Pereira
> >
> > > --
> > > Você recebeu esta mensagem porque está inscrito na lista "flexdev"
> > > Para enviar uma mensagem, envie um e-mail para
> [email protected]
> > > Para sair da lista, envie um email em branco para
> > > [email protected]
> > > Mais opções estão disponíveis emhttp://groups.google.com/group/flexdev
> >
> > --
> > Bruno Soareshttp://www.brunosoares.com
>
> --
> Você recebeu esta mensagem porque está inscrito na lista "flexdev"
> Para enviar uma mensagem, envie um e-mail para [email protected]
> Para sair da lista, envie um email em branco para
> [email protected]
> Mais opções estão disponíveis em http://groups.google.com/group/flexdev
>



-- 
Clayton Marques Pereira

-- 
Você recebeu esta mensagem porque está inscrito na lista "flexdev"
Para enviar uma mensagem, envie um e-mail para [email protected]
Para sair da lista, envie um email em branco para 
[email protected]
Mais opções estão disponíveis em http://groups.google.com/group/flexdev

Responder a