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 중국어 웹사이트의 기타 관련 기사를 참조하세요!