A instrução SELECT possui duas cláusulas poderosas, pouco compreendidas e usadas: GROUP BY e HAVING.
A cláusula GROUP BY organiza dados em grupos, produzindo sumários. A
cláusula HAVING estabelece condições para listar esses grupos. Dizemos
que a cláusula HAVING está para a cláusula GROUP BY, assim como a
cláusula WHERE está para o comando SELECT.
A sintaxe do comando SELECT com as cláusulas GROUP BY e HAVING é:
SELECT <coluna(s)>
FROM <tabela>
WHERE <condições>
GROUP BY <coluna(s)>
HAVING <condições>
Seguem aplicações dessas cláusulas baseadas nessa tabela:
1)Qual o total das vendas?
SELECT SUM(valor)
FROM vendas
2)Qual o total das vendas de cada vendedor?
SELECT vendedor, SUM(valor)
FROM vendas
GROUP BY vendedor
3)Quantas vendas foram feitas?
SELECT COUNT(*)
FROM vendas
4)Quantas vendas cada vendedor fez?
SELECT vendedor, COUNT(*)
FROM vendas
GROUP BY vendedor
5)Qual a menor e a maior venda?
SELECT MIN(valor), MAX(valor)
FROM vendas
6)Qual a menor e a maior venda de cada vendedor?
SELECT vendedor, MIN(valor), MAX(valor)
FROM vendas
GROUP BY vendedor
7)Qual a média das vendas dos dias 15 e 17?
SELECT data, AVG(valor)
FROM vendas
WHERE data IN ('2008-04-15', '2008-04-17')
GROUP BY data
8)Em quais dias as vendas superaram 3.000?
SELECT data, SUM(valor)
FROM vendas
GROUP BY data
HAVING SUM(valor) >3000
9)Em quais dias, no período de 14 a 16/04/2008, a média das vendas foi menor que 2000?
SELECT data, AVG(valor)
FROM vendas
WHERE data BETWEEN '2008-04-14' AND '2008-04-16'
GROUP BY data
HAVING AVG(valor) <2000
10)Que vendedores fecharam mais de 2 vendas nos dias 14, 16 e 18 de 04 de 2008?
SELECT vendedor, COUNT(*)
FROM vendas
WHERE data IN ('2008-04-14', '2008-04-16', '2008-04-18')
GROUP BY vendedor
HAVING COUNT(*) >2
É isso, pessoal! Os exemplos usaram apenas funções agregadas. Com stored procedures, o céu torna-se o limite para as queries.
Fonte: http://www.infoblogs.com.br/view.action?contentId=33915&GROUP-BY-e-HAVING-essas-incompreendidas-clausulas-SELECT.html
Tenho 3 linhas que foram agrupadas com o GROUP BY, ele me retorna a primeira linha, porem, quero a linha que tem a maior data.
ResponderExcluirComo fazer essa seleção??
Pode colocar um ORDER BY no campo Data.
ResponderExcluirMas para ajudar mesmo seria bom saber a estrutura de suas tabelas e o seu SELECT Moisés =D