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