집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!