• Matéria: Informática
  • Autor: facuta
  • Perguntado 4 anos atrás

Uma cláusula “group by”, parte do comando SELECT, permite criar agrupamentos, isto é, vários registros com os mesmos valores são combinados em uma linha e os valores dos outros campos podem ser resumidos através de funções de agregação, gerando cálculo de totais, contagens, médias e outros.
Em um sistema de livraria, existe uma tabela LIVRO que contém os seguintes campos:

LIVRO (COD_LIVRO, TITULO, AUTOR, VALOR)


Para recuperar a lista dos autores com o total de títulos de sua autoria presentes na livraria e o valor médio dos valores de seus títulos, a consulta deve ser:

SELECT TITULO, SUM(*), AVG(VALOR) FROM LIVRO GROUP BY TITULO

SELECT TITULO, COUNT(*), AVG(VALOR) FROM LIVRO GROUP BY TITULO

SELECT AUTOR, SUM(*), MEDIA(VALOR) FROM LIVRO GROUP BY AUTOR

SELECT AUTOR, COUNT(*), AVG(VALOR) FROM LIVRO GROUP BY AUTOR

SELECT AUTOR, COUNT(*), MEDIA(VALOR) FROM LIVRO GROUP BY AUTOR

Respostas

respondido por: fredealevi
29

Resposta:

SELECT      AUTOR, COUNT(*), AVG(VALOR)         FROM LIVRO GROUP BY AUTOR

Explicação:

A alternativa está correta pois o agrupamento (group by) ocorre por AUTOR que é o campo junto ao SELECT e é requisitado contagem e média por autor tratadas com as funções de contagem (COUNT(*) ) e a média (AVG(VALOR) ) aplicadas corretamente.

Perguntas similares