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.
Question
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 to comment
Share on other sites
1 answer to this question
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.