MySQL에서 이름별로 그룹화하기 전에 날짜 및 시간별로 정렬하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-30 09:23:27
원래의
142명이 탐색했습니다.

How to Sort by Date and Time before Grouping by Name in MySQL?

MySQL에서 정렬 및 그룹화 관리: 특정 결과에 대해 ORDER BY 및 GROUP BY 결합

MySQL에서 원하는 정렬 및 그룹화 달성 작업 순서가 충돌하면 데이터가 어려울 수 있습니다. 이 질문은 데이터를 이름별로 그룹화하기 전에 날짜 및 시간별로 정렬하는 것이 목표인 시나리오를 제시합니다.

사용자가 설명했듯이 ORDER BY 날짜 ASC, 시간 ASC, GROUP BY 이름을 사용하는 표준 접근 방식입니다. 쿼리에서 GROUP BY가 ORDER BY 앞에 와야 하기 때문에 실패합니다. 이 충돌을 해결하기 위해 답변에서는 두 가지 대체 방법을 제공합니다.

방법 1: 하위 쿼리

첫 번째 방법은 그룹화하기 전에 하위 쿼리를 사용하여 원하는 순서를 얻는 것입니다.

<code class="sql">SELECT * 
FROM (
    SELECT * FROM table_name
    ORDER BY date ASC, time ASC 
) AS sub
GROUP BY name</code>
로그인 후 복사

이 하위 쿼리는 날짜 및 시간별로 정렬된 데이터가 포함된 임시 테이블 sub를 생성합니다. 그런 다음 기본 쿼리는 이 임시 테이블을 이름별로 그룹화하여 원하는 결과를 얻습니다.

방법 2: 공통 테이블 표현식(CTE) 사용

일반적으로 사용되는 또 다른 방법 MySQL 버전 8.0 이상에서는 CTE(공통 테이블 표현식)를 생성하여 정렬 및 그룹화를 수행합니다.

<code class="sql">WITH sorted_data AS (
    SELECT * FROM table_name
    ORDER BY date ASC, time ASC 
)
SELECT * 
FROM sorted_data
GROUP BY name</code>
로그인 후 복사

CTE인 sorted_data는 임시 테이블을 생성하여 하위 쿼리와 동일한 결과를 얻습니다. 정렬된 데이터로 그룹화를 위한 기본 쿼리에 사용됩니다.

위 내용은 MySQL에서 이름별로 그룹화하기 전에 날짜 및 시간별로 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!