>데이터 베이스 >MySQL 튜토리얼 >IN() 절에 지정된 순서로 MySQL 결과를 정렬하는 방법은 무엇입니까?

IN() 절에 지정된 순서로 MySQL 결과를 정렬하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-12 17:28:01776검색

How to Sort MySQL Results by the Order Specified in the IN() Clause?

MySQL: IN() 지정 순서에 따라 결과 정렬

IN() 절을 사용하여 데이터를 검색할 때 IN() 절이 있는 순서를 유지합니다. 값을 지정하면 출력의 가독성과 유용성을 향상시킬 수 있습니다. 이 문서에서는 IN() 함수 내의 값 순서에 따라 결과를 정렬하는 솔루션을 살펴봅니다.

다음 쿼리를 고려하세요.

SELECT id, name FROM mytable WHERE name IN ('B', 'A', 'D', 'E', 'C');

이 쿼리는 다음 출력을 반환합니다. 행 순서가 IN() 절의 순서와 일치하지 않습니다:

| 아이디 | 이름 |
^---------^---------^
| 5 | ㄴ |
| 6 | ㄴ |
| 1 | ㄷ |
| 15 | 이자 |
| 17 | 이자 |
| 9 | ㄷ |
| 18 | C |

IN() 절에 지정된 순서대로 결과를 정렬하려면 FIELD 함수를 활용하면 됩니다. FIELD 함수는 값을 첫 번째 인수로 사용하고 나머지 인수 목록에서 해당 값의 위치를 ​​반환합니다.

다음 쿼리는 FIELD 함수를 사용하여 '이름'의 위치를 ​​기준으로 결과를 정렬합니다. 목록의 열 값('B', 'A', 'D', 'E', 'C'):

SELECT id, name
FROM mytable
WHERE name IN ('B', 'A', 'D', 'E', 'C')
ORDER BY FIELD(name, 'B', 'A', 'D', 'E', 'C')

이 쿼리는 다음을 반환합니다. 출력:

| 아이디 | 이름 |
^---------^---------^
| 5 | ㄴ |
| 6 | ㄴ |
| 1 | ㄷ |
| 15 | 이자 |
| 17 | 이자 |
| 9 | ㄷ |
| 18 | C |

보시다시피 이제 원래 IN() 절에 지정된 순서대로 행이 정렬됩니다.

위 내용은 IN() 절에 지정된 순서로 MySQL 결과를 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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