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

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

Patricia Arquette
풀어 주다: 2024-12-15 05:07:17
원래의
445명이 탐색했습니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿