Minicursos - MySQL

Group By


O parâmetro GROUP BY é muito interessante, pois nos permite agrupar resultados de acordo com qualquer elemento presente na tabela. Isso nos permite uma análise muito mais apurada dos dados. Para demonstrar seu funcionamento, vamos popular nossa tabela "aluga", que de todas as criadas neste minicurso é a única que ainda não possui dados.

Vamos relembrar, através do comando "desc aluga", a estrutura que esta tabela possui, para que possamos fazer a inserção de dados nela:

Group By MySQL

Ela possui as colunas CPF, que é uma chave estrangeira da tabela "cliente". A coluna codigo, que é chave estrangeira do código contido na tabela "filme". E a coluna data, que armazena a data da locação do filme. Vou inserir os seguintes dados:

INSERT INTO aluga VALUES ("123321123-33", 2, "2011-12-01");

INSERT INTO aluga VALUES ("123321123-33", 1, "2011-12-01");

INSERT INTO aluga VALUES ("123321123-33", 3, "2011-12-01");

INSERT INTO aluga VALUES ("756398336-20", 3, "2011-12-03");

INSERT INTO aluga VALUES ("756398336-20", 6, "2011-12-03");

INSERT INTO aluga VALUES ("756398336-20", 5, "2011-12-01");

INSERT INTO aluga VALUES ("756398336-20", 1, "2011-12-01");

INSERT INTO aluga VALUES ("389476625-11", 1, "2011-12-01");

Agora nossa tabela "aluga" contém os seguintes dados:

Group By MySQL

Agora vamos imaginar que quiséssemos saber quantos filmes cada um dos clientes alugou. Você talvez tenha pensado em fazer um SELECT COUNT, mas veja o que acontece se fizermos isso:

Group By MySQL

O sistema nos retornou todas as pessoas que já alugaram filmes. Sabemos, portanto, que foram 8 locações, mas quantos clientes estão presentes nestas 8 locações não é possível saber. Isso acontece porque os CPFs não estão agrupados, ou seja, não é possível conta-los separadamente. É aí que o GROUP BY vai atuar, criando pequenos grupos de cada CPF, para que possamos efetuar a contagem dessa forma. É mais simples do que parece, vejam:

SELECT count(cpf) AS 'Qtde de Filmes Alugados', cpf AS CPF FROM aluga GROUP BY (cpf);

Group By MySQL

Vejam só que bacana, o comando nos retornou exatamente o que queríamos. Vamos interpretar esse comando. Estamos pedindo ao SGBD o seguinte:

Conte os CPFs e exiba-os com o rótulo de “Qtde de Filmes Alugados”, exiba também a coluna "cpf" com o rótulo de CPF, ambos da tabela "aluga", AGRUPADOS POR CPF.

É esse GROUP BY(cpf) que permite a contagem correta dos filmes alugados a partir dos seus CPF.

Poderíamos ainda fazer um INNER JOIN e exibir os nomes dos clientes, vejam que interessante:

SELECT count(aluga.cpf) AS 'Qtde de Filmes Alugados', aluga.cpf AS CPF, nome AS Cliente FROM aluga INNER JOIN cliente ON cliente.cpf=aluga.cpf GROUP BY (cpf);

E o retorno seria:

Group By MySQL

Espero que tenha ficado claro qual a função desse importante parâmetro, que é o GROUP BY.




Algumas notícias

Google lança programa para capacitar profissionais brasileiros e com direito a bolsas

O Google iniciou nesta terça-feira (17) o Certificado Profissional de Suporte em TI para brasileiros. Trata-se de um curso desenvolvido pela gigante de tecnologia em parceria com a Coursera. Inicialmente, o módulo de ensino foi anunciado a um valor de US$ 39 por mês. Entretanto, sofreu uma redu...

Ler Notícia Completa

Intel Core i9-9900KS é um monstro com frequência de 5GHz em todos os núcleos

A Intel é uma das empresas presentes na Computex 2019, a maior feira de hardware da Ásia. E a empresa começou a esquentar os motores antes mesmo do início das conferências, exibindo um processador que não está para brincadeira: o Intel Core i9-9900KS, uma edição especial e ainda mais turbinada do...

Ler Notícia Completa
Você gostará destes vídeos: