>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 UNION을 사용한 후 카테고리 내에서 결과를 정렬하려면 어떻게 해야 합니까?

MySQL에서 UNION을 사용한 후 카테고리 내에서 결과를 정렬하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-11 11:43:44620검색

How Can I Sort Results Within Categories After Using UNION in MySQL?

MySQL에서 UNION 쿼리 결과 정렬

MySQL에서 UNION 연산자를 사용하여 여러 데이터 소스의 데이터를 처리할 때 결과 정렬이 어려울 수 있으며, 특히 특정 범주 내에서 결과를 정렬해야 하는 경우 더욱 그렇습니다. 이 문제는 일반적으로 다양한 기준(예: 검색 쿼리의 거리 필터링)을 기반으로 단일 테이블에서 데이터를 추출할 때 발생합니다.

문제 설명

주어진 시나리오에서 세 가지 개별 쿼리는 서로 다른 거리 조건을 기반으로 데이터를 추출합니다.

  1. 완전히 일치 검색
  2. 5km 이내 거리
  3. 5~15km 이내 거리

그런 다음 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_datedistance 열을 포함한다고 가정합니다. 실제 테이블 구조 및 조건에 따라 적절하게 조정하십시오.

위 내용은 MySQL에서 UNION을 사용한 후 카테고리 내에서 결과를 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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