집 >데이터 베이스 >MySQL 튜토리얼 >IN 절의 값 순서에 따라 PostgreSQL 결과를 정렬하려면 어떻게 해야 합니까?
IN 절을 사용하여 PostgreSQL 쿼리에서 행 순서 제어
PostgreSQL의 IN
절은 필터링에 강력하기는 하지만 본질적으로 특정 행 순서를 보장하지는 않습니다. IN
목록의 순서에 따라 정렬된 행을 검색해야 하는 경우 VALUES
구문(PostgreSQL 8.2 이상에서 사용 가능)을 사용하는 해결 방법이 해결책을 제공합니다.
이 접근 방식은 IN
목록의 ID를 사용자 정의 순서에 매핑하는 하위 쿼리를 생성합니다. 그런 다음 기본 쿼리는 이 하위 쿼리를 결합하여 결과를 정렬합니다. 방법은 다음과 같습니다.
<code class="language-sql">SELECT c.* FROM comments c JOIN ( VALUES (1,1), (3,2), (2,3), (4,4) ) AS x (id, ordering) ON c.id = x.id ORDER BY x.ordering;</code>
이 쿼리는 x
을 사용하여 임시 테이블(VALUES
)을 구성합니다. x
의 각 행은 IN
목록의 ID와 원하는 순서(ordering
)를 연결합니다. JOIN
작업은 이 임시 테이블을 comments
열을 기반으로 id
테이블에 연결합니다. 마지막으로 ORDER BY x.ordering
은 VALUES
구문
이 방법을 사용하면 IN
절과 관련된 쿼리에서 반환된 행의 순서를 효과적으로 사용자 정의하여 데이터 표시를 정밀하게 제어할 수 있습니다.
위 내용은 IN 절의 값 순서에 따라 PostgreSQL 결과를 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!