>데이터 베이스 >MySQL 튜토리얼 >IN 절의 값 순서에 따라 PostgreSQL 결과를 정렬하려면 어떻게 해야 합니까?

IN 절의 값 순서에 따라 PostgreSQL 결과를 정렬하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-19 10:51:10447검색

How Can I Order PostgreSQL Results Based on the Order of Values in an IN Clause?

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.orderingVALUES 구문

에 정의된 순서에 따라 결과를 정렬합니다.

이 방법을 사용하면 IN 절과 관련된 쿼리에서 반환된 행의 순서를 효과적으로 사용자 정의하여 데이터 표시를 정밀하게 제어할 수 있습니다.

위 내용은 IN 절의 값 순서에 따라 PostgreSQL 결과를 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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