>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 집계 함수를 사용하여 그룹화된 행에서 첫 번째 및 마지막 레코드를 검색하는 방법은 무엇입니까?

MySQL에서 집계 함수를 사용하여 그룹화된 행에서 첫 번째 및 마지막 레코드를 검색하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-20 00:56:02416검색

How to Retrieve the First and Last Records from Grouped Rows with Aggregate Functions in MySQL?

MySQL에서 집계 함수를 사용하여 그룹화된 행에서 첫 번째 및 마지막 레코드 검색

SQL에서 집계 함수를 사용하면 그룹 전체에서 데이터를 효율적으로 요약할 수 있습니다. . 그러나 그룹화된 레코드를 접할 때 사용자는 각 그룹의 첫 번째 레코드와 마지막 레코드를 검색하는 데 어려움을 겪을 수 있습니다. 이는 대규모 테이블로 작업할 때 특히 중요합니다.

다음 쿼리를 고려하십시오.

SELECT MIN(low_price), MAX(high_price), open, close
FROM symbols
WHERE date BETWEEN(.. ..)
GROUP BY YEARWEEK(date)

이 쿼리는 각 그룹에 대한 집계 통계(예: 최소 및 최대 가격)를 제공하지만 매주 첫 번째와 마지막 기록을 제공하지 않습니다. 이러한 요구를 해결하기 위해 MySQL은 여러 가지 접근 방식을 제공합니다.

GROUP_CONCAT 및 SUBSTRING_INDEX 사용

효율적인 기술 중 하나는 GROUP_CONCAT 및 SUBSTRING_INDEX 함수를 활용하는 것입니다. GROUP_CONCAT은 그룹 내의 지정된 값을 구분 기호로 구분하여 연결합니다. 그러면 SUBSTRING_INDEX는 연결된 문자열에서 하위 문자열을 추출합니다.

이러한 함수를 활용하여 원하는 결과를 얻을 수 있는 방법은 다음과 같습니다.

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 

이 접근 방식은 값비싼 하위 쿼리가 필요하지 않으며 높은 성능을 입증합니다. 이러한 특정 시나리오에 효율적입니다.

GROUP_CONCAT 및 SUBSTRING_INDEX 함수에 대한 자세한 내용은 공식 MySQL 설명서를 참조하세요.

위 내용은 MySQL에서 집계 함수를 사용하여 그룹화된 행에서 첫 번째 및 마지막 레코드를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.