"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como recuperar com eficiência o primeiro e o último registro de dados agrupados no MySQL?

Como recuperar com eficiência o primeiro e o último registro de dados agrupados no MySQL?

Publicado em 2024-11-16
Navegar:986

How to Efficiently Retrieve First and Last Records of Grouped Data in MySQL?

Recuperando o primeiro e o último registros de dados agrupados com funções agregadas no MySQL

No MySQL, ao buscar dados de registros agrupados usando funções agregadas, pode ser um desafio recuperar o primeiro e o último registro do grupo. Embora múltiplas consultas possam fazer isso, isso pode ser ineficiente para tabelas grandes.

Para otimizar esse processo, o MySQL oferece uma solução mais eficiente usando as funções GROUP_CONCAT e SUBSTRING_INDEX .

Usando GROUP_CONCAT e SUBSTRING_INDEX

Usando essas funções juntas, você pode concatenar valores do grupo e depois extrair o primeiro e o último valores usando SUBSTRING_INDEX. Veja como:

SUBSTRING_INDEX(GROUP_CONCAT(CAST(open AS CHAR) ORDER BY datetime), ',', 1) AS open
SUBSTRING_INDEX(GROUP_CONCAT(CAST(close AS CHAR) ORDER BY datetime DESC), ',', 1) AS close

Como funciona:

  • GROUP_CONCAT concatena todos os valores de abertura ou fechamento em uma única string, classificada por data e hora column.
  • SUBSTRING_INDEX extrai o primeiro e o último valores da string concatenada dividindo-a na vírgula (','). O argumento '1' indica a primeira ou última ocorrência.

Exemplo:

Considere a seguinte consulta:

SELECT MIN(low_price), MAX(high_price),
SUBSTRING_INDEX(GROUP_CONCAT(CAST(open AS CHAR) ORDER BY datetime), ',', 1) AS open,
SUBSTRING_INDEX(GROUP_CONCAT(CAST(close AS CHAR) ORDER BY datetime DESC), ',', 1) AS close
FROM symbols
WHERE date BETWEEN(.. ..)
GROUP BY YEARWEEK(date)

Esta consulta recupera com eficiência o primeiro (aberto) e o último (fechado) registros de cada grupo, minimizando o tempo de processamento para tabelas grandes.

Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3