MySQL에서 UNION 쿼리 결과 정렬
MySQL에서 UNION 연산자를 사용하여 여러 데이터 소스의 데이터를 처리할 때 결과 정렬이 어려울 수 있으며, 특히 특정 범주 내에서 결과를 정렬해야 하는 경우 더욱 그렇습니다. 이 문제는 일반적으로 다양한 기준(예: 검색 쿼리의 거리 필터링)을 기반으로 단일 테이블에서 데이터를 추출할 때 발생합니다.
문제 설명
주어진 시나리오에서 세 가지 개별 쿼리는 서로 다른 거리 조건을 기반으로 데이터를 추출합니다.
그런 다음 UNION을 사용하여 이러한 결과를 결합하고 적절한 제목 아래에 표시합니다(예: "정확한 결과" 및 "5km 이내의 결과"). 사용자는 ID 또는 add_date를 기준으로 결과를 정렬하려고 하지만 병합 쿼리 끝에 ORDER BY 절을 추가하면 제목별로 정렬할 필요가 없이 모든 결과가 전체적으로 정렬됩니다.
순위 의사 열을 사용한 솔루션
결과를 병합하는 동안 각 카테고리 내에서 결과를 정렬하려면 각 선택 쿼리에 "순위"라는 의사 열을 도입할 수 있습니다. 이 열은 실제 기준으로 정렬하기 전에 정렬 기준으로 사용됩니다. 다음 코드는 이 접근 방식을 보여줍니다.
<code class="language-sql">SELECT * FROM ( SELECT 1 AS Rank, id, add_date FROM Table WHERE <精确匹配条件> UNION ALL SELECT 2 AS Rank, id, add_date FROM Table WHERE distance < 5 UNION ALL SELECT 3 AS Rank, id, add_date FROM Table WHERE distance BETWEEN 5 AND 15 ) AS CombinedResults ORDER BY Rank, id DESC, add_date DESC;</code>
이 쿼리에서 Rank 의사 열은 세 쿼리에 각각 1, 2, 3의 값을 할당합니다. ORDER BY 절은 먼저 순위를 기준으로 결과를 정렬한 다음 ID 및 add_date를 기준으로 내림차순으로 정렬합니다. 이 접근 방식을 사용하면 카테고리 구분을 유지하면서 각 제목 내에서 결과를 정렬할 수 있습니다.
<精确匹配条件>
은 정확히 일치하는 검색 기준으로 바꿔야 합니다. 이 솔루션은 테이블 이름이 Table
이고 id
, add_date
및 distance
열을 포함한다고 가정합니다. 실제 테이블 구조 및 조건에 따라 적절하게 조정하십시오.
위 내용은 MySQL에서 UNION을 사용한 후 카테고리 내에서 결과를 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!