Ir para o conteúdo
  • Revista PROGRAMAR: Já está disponível a edição #60 da revista programar. Faz já o download aqui!

batistavn15

[Resolvido] Calcular média

Mensagens Recomendadas

batistavn15

Boas pessoal, estou com um problema na realização de uma querie, e agradecia a vossa ajuda.

É o seguinte eu tenho 2 tabelas: aluno e notas, e aparece o nome do aluno e respectiva nota, mas depois gostava que numa nova coluna visualiza-se a média de todas as notas numa só linha. Ou seja tenho "n" linhas dos nomes e notas dos alunos e depois queria 1 nova coluna com apenas uma linha com a média das notas.

Aqui deixo a a querie como está até ao momento:

select nome, nota from
(
SELECT nome, notas.nota
from alunos
INNER JOIN notas ON alunos.id = notas.id_aluno
UNION
SELECT null, null, AVG(notas.nota)
FROM notas
)
as aaa

Obrigado

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
Rui Carlos

Não percebi qual o objectivo da query mais exterior.

O problema pode estar no facto de estares a juntar (UNION) tabelas com um número diferente de colunas.

Experimenta com

SELECT NULL, AVG(notas.nota)
FROM notas

Já agora, dava jeito indicares quais eram os problemas da query que estavas a usar.

Por acaso ele já tem um AVG na query dele, pelo que me parece que esse comentário é desnecessário.

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
batistavn15

Não percebi qual o objectivo da query mais exterior.

O problema pode estar no facto de estares a juntar (UNION) tabelas com um número diferente de colunas.

Experimenta com

SELECT NULL, AVG(notas.nota)
FROM notas

Já agora, dava jeito indicares quais eram os problemas da query que estavas a usar.

Por acaso ele já tem um AVG na query dele, pelo que me parece que esse comentário é desnecessário.

Muito obrigado por a resposta. Assim como me disse funciona mas no fim de mostrar todos os campos, o que queria saber era se era possivel aparecer uma nova coluna onde se visualiza-se a média logo em cima e não no fim

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax
Por acaso ele já tem um AVG na query dele, pelo que me parece que esse comentário é desnecessário.

Nao tinha reparado, que ele tinha a funcao.

SELECT a.nome, n.nota, (SELECT AVG(nn.Notas) FROM notas nn WHERE nn.id_aluno = a.id /*AND nn.TipoID = notas.TipoID --Para Saber as medias de uma disciplica, caso tenhas na BD*/) as 'media'
FROM alunos a
INNER JOIN notas n ON a.id = n.id_aluno

Editado por pikax
  • Voto 1

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
batistavn15

Nao tinha reparado, que ele tinha a funcao.

SELECT a.nome, n.nota, (SELECT AVG(nn.Notas) FROM notas nn WHERE nn.id_aluno = a.id /*AND nn.TipoID = notas.TipoID --Para Saber as medias de uma disciplica, caso tenhas na BD*/) as 'media'
FROM alunos a
INNER JOIN notas n ON a.id = n.id_aluno

Já está, muito obrigado por a ajuda :)

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
Rui Carlos

Muito obrigado por a resposta. Assim como me disse funciona mas no fim de mostrar todos os campos, o que queria saber era se era possivel aparecer uma nova coluna onde se visualiza-se a média logo em cima e não no fim

Ok, pensei que o objectivo era mostrar uma nova linha :) (o "1 só linha" está um pouco confuso).

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites

Crie uma conta ou ligue-se para comentar

Só membros podem comentar

Criar nova conta

Registe para ter uma conta na nossa comunidade. É fácil!

Registar nova conta

Entra

Já tem conta? Inicie sessão aqui.

Entrar Agora

×

Aviso Sobre Cookies

Ao usar este site você aceita os nossos Termos de Uso e Política de Privacidade. Este site usa cookies para disponibilizar funcionalidades personalizadas. Para mais informações visite esta página.