> 데이터 베이스 > MySQL 튜토리얼 > SQL UNION 쿼리의 결과를 올바르게 정렬하는 방법은 무엇입니까?

SQL UNION 쿼리의 결과를 올바르게 정렬하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-09 22:33:44
원래의
677명이 탐색했습니다.

How to Properly Order Results from a SQL UNION Query?

SQL UNION 쿼리 정렬

UNION 연산자를 사용하여 여러 테이블의 데이터를 결합하기 위해 SQL 쿼리를 사용할 때 결과를 정렬해야 하는 경우가 많습니다. 그러나 단순히 쿼리 끝에 ORDER BY 절을 추가하면 오류가 발생할 수 있습니다.

다음 예를 고려해 보세요.

<code class="language-sql">SELECT table1.field1 FROM table1 ORDER BY table1.field1
UNION
SELECT table2.field1 FROM table2 ORDER BY table2.field1</code>
로그인 후 복사

이 쿼리는 UNION 연산의 결과를 정렬하려고 시도하지만 개별 SELECT 문을 둘러싼 괄호 외부에서 ORDER BY 절이 허용되지 않기 때문에 예외가 발생합니다.

UNION 쿼리를 올바르게 정렬하려면 모든 SELECT 문에 ORDER BY 절을 포함해야 합니다. 이렇게 하면 개별 데이터 세트가 결합되기 전에 정렬됩니다. 결과를 올바르게 정렬하기 위해 위 쿼리를 다시 작성하는 방법은 다음과 같습니다.

<code class="language-sql">SELECT * FROM
(
  SELECT table1.field1 FROM table1 ORDER BY table1.field1
) DUMMY_ALIAS1

UNION ALL

SELECT * FROM
(
  SELECT table2.field1 FROM table2 ORDER BY table2.field1
) DUMMY_ALIAS2</code>
로그인 후 복사

이 접근 방식을 사용하면 개별 데이터 세트가 UNION ALL을 사용하여 결합되기 전에 괄호 안에 정렬됩니다. 결합된 결과는 가장 바깥쪽 SELECT 문의 ORDER BY 절 요구 사항에 따라 정렬됩니다.

위 내용은 SQL UNION 쿼리의 결과를 올바르게 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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