Estou com dificuldades para realizar uma consulta, pois não domino ainda as ordens de sintaxe SQL.
Um anuncio tem um status e várias imagens. Quero contar quantas imagens tem o anuncio.
Primeiro tentei assim:
select
anuncios.*, statusanuncio.nome as status
from
anuncios, imagens, statusanuncio
left join
count(imagens.idanun) as n on imagens.idanun=anuncios.id
where
statusanuncio.id=anuncios.idstatusanuncio and anuncios.idcli='1'
group by
imagens.idanun"
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'count(imagens.idanun) as n on imagens.idanun=anuncios.id where statusa' at line 6
Aí me orientaram a fazer assim:
select
anuncios.*,
statusanuncio.nome as status,
count(imagens.idanun) as n
from
anuncios, imagens, statusanuncio
left join
imagens on imagens.idanun=anuncios.id
where
statusanuncio.id=anuncios.idstatusanuncio and anuncios.idcli='1'
Unknown column 'anuncios.id' in 'on clause'
E então:
select
anuncios.*, statusanuncio.nome as status, count(n.idanun) as contador
from
anuncios, statusanuncio
left join
images as n on n.idanun=anuncios.id
where
statusanuncio.id=anuncios.idstatusanuncio and anuncios.idcli='1'
group by
imagens.idanun
Unknown column 'anuncios.id' in 'on clause'
Eu não entendo ainda muito bem de SQL e porque o Left Join não encontra o anuncios.id no 3o caso.
Se alguém puder explicar esse tipo de "escopo" entre os comandos eu agradeço.
Pergunta
lcerbaro
Bom dia.
Estou com dificuldades para realizar uma consulta, pois não domino ainda as ordens de sintaxe SQL.
Um anuncio tem um status e várias imagens. Quero contar quantas imagens tem o anuncio.
Primeiro tentei assim:
Aí me orientaram a fazer assim: E então:Eu não entendo ainda muito bem de SQL e porque o Left Join não encontra o anuncios.id no 3o caso.
Se alguém puder explicar esse tipo de "escopo" entre os comandos eu agradeço.
Link para o comentário
Compartilhar em outros sites
1 resposta a esta questão
Posts Recomendados
Participe da discussão
Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.