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 중국어 웹사이트의 기타 관련 기사를 참조하세요!