>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 데이터를 주문할 때 NULL 값이 마지막에 표시되도록 하려면 어떻게 해야 합니까?

MySQL에서 데이터를 주문할 때 NULL 값이 마지막에 표시되도록 하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-15 05:07:17514검색

How Can I Make NULL Values Appear Last When Ordering Data in MySQL?

MySQL 순서 지정에서 Null 값 유지

MySQL에서 Null 값이 있는 데이터를 정렬하는 것은 문제가 될 수 있습니다. 기본. 이로 인해 Null 값이 Null이 아닌 값 앞에 나타나는 의도하지 않은 정렬 동작이 발생할 수 있습니다. 이 문제를 해결하기 위해 잘 알려지지 않은 구문을 사용하여 null 값이 정렬된 결과의 마지막에 나타나도록 할 수 있습니다.

Null 정렬 역순

MySQL은 문서화되지 않은 Null 값의 정렬 순서를 반대로 할 수 있는 구문입니다. 열 이름 앞에 빼기 기호(-)를 붙이고 ASC를 DESC로 전환하면 MySQL이 정렬 순서에서 null을 가장 높은 값으로 처리하도록 지시할 수 있습니다.

예를 들어 다음 ORDER BY 절을 고려해보세요. :

ORDER BY -position DESC, id DESC

이 절은 위치 열을 내림차순으로 정렬하며 null 값은 마지막에 나타납니다. id 열은 여전히 ​​내림차순으로 정렬됩니다.

다음 데이터가 포함된 테이블이 있다고 가정합니다.

| position | id |
|---|---|
| null | 10 |
| null | 11 |
| null | 12 |
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |
| 4 | 4 |

사용 전통적인 ORDER BY 절(위치 ASC, ID DESC)을 사용하면 결과는 다음과 같이 정렬됩니다. 다음은 다음과 같습니다.

| position | id |
|---|---|
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |
| 4 | 4 |
| null | 12 |
| null | 11 |
| null | 10 |

그러나 역방향 null 정렬 구문(-position DESC, id DESC)을 사용하면 null 값이 마지막에 나타나는 원하는 순서를 얻을 수 있습니다.

| position | id |
|---|---|
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |
| 4 | 4 |
| null | 10 |
| null | 11 |
| null | 12 |

참고:

이 기술은 문서화되지 않았으며 모든 MySQL에서 지원되지 않을 수 있습니다. 버전. 호환성을 확인하려면 특정 버전에 대한 MySQL 설명서를 참조하세요.

위 내용은 MySQL에서 데이터를 주문할 때 NULL 값이 마지막에 표시되도록 하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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