>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 CASE 문을 사용하여 특정 ID에 따라 우선 순위가 지정된 타임스탬프별로 행을 정렬하는 방법은 무엇입니까?

MySQL에서 CASE 문을 사용하여 특정 ID에 따라 우선 순위가 지정된 타임스탬프별로 행을 정렬하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-23 06:00:18280검색

How to Order Rows by Timestamps Prioritized by Specific IDs using CASE Statement in MySQL?

MYSQL ORDER BY CASE 문제: 주문을 위한 타임스탬프 결합

제시된 시나리오에는 4개의 행이 있는 테이블이 있습니다. 두 개의 ID와 두 개의 타임스탬프를 포함합니다. 작업은 4개의 행을 모두 검색하고 특정 방식으로 타임스탬프를 기준으로 순서를 지정하는 것입니다.

목표는 id_one이 27과 일치할 때 순서를 위해 timestamp_one 열의 우선 순위를 지정하고, id_two가 27과 일치할 때 timestamp_two 열의 우선 순위를 지정하는 것입니다. 예상되는 출력은 두 타임스탬프 열이 하나인 것처럼 행을 정렬하는 것입니다.

달성하려면 이를 위해 기존 명령문을 다음과 같이 수정할 수 있습니다.

SELECT id_one, id_two, timestamp_one, timestamp_two
FROM tablename
WHERE id_one = 27
    OR id_two = 27
ORDER BY
    CASE
        WHEN id_one=27 THEN timestamp_one
        WHEN id_two=27 THEN timestamp_two
    END DESC

이 업데이트된 명령문에서는 id_one이 27일 때 timestamp_one, id_two가 27일 때 timestamp_two를 기준으로 정렬 우선 순위를 지정합니다. CASE 문은 올바른 타임스탬프 열이 있는지 확인합니다. 각 행에 사용됩니다.

결과 출력은 다음과 같이 정렬됩니다. 다음은 다음과 같습니다.

-------------------------------------------------------------------
|   id_one   |   id_two   |   timestamp_one   |   timestamp_two   |
-------------------------------------------------------------------
|     27     |     35     |        9:30       |        NULL       |
-------------------------------------------------------------------
|     35     |     27     |        NULL       |        9:33       |
-------------------------------------------------------------------
|     27     |     35     |        9:34       |        NULL       |
-------------------------------------------------------------------
|     35     |     27     |        NULL       |        9:35       |
-------------------------------------------------------------------

이는 id_one이 27인 행에 대해 timestamp_one의 우선순위를 지정하고 id_two가 27인 행에 대해 timestamp_two의 우선순위를 지정하여 마치 두 개의 타임스탬프 열이 하나인 것처럼 행을 정렬해야 하는 요구 사항을 충족합니다.

위 내용은 MySQL에서 CASE 문을 사용하여 특정 ID에 따라 우선 순위가 지정된 타임스탬프별로 행을 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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