> 데이터 베이스 > MySQL 튜토리얼 > ORDER BY를 사용하여 MySQL에서 영숫자 데이터를 올바르게 정렬하려면 어떻게 해야 합니까?

ORDER BY를 사용하여 MySQL에서 영숫자 데이터를 올바르게 정렬하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-12 14:25:12
원래의
622명이 탐색했습니다.

How Can I Correctly Sort Alphanumeric Data in MySQL Using ORDER BY?

MySQL "Order By" - 영숫자 데이터를 올바르게 정렬

문제:

사용 시 MySQL의 영숫자 데이터가 포함된 "ORDER BY" 절, 정렬이 자주 수행됨 첫 번째 숫자에 우선순위를 부여하므로 잘못된 순서가 발생합니다. 예를 들어 다음 데이터는 다음과 같습니다.

1
2
3
4
5
6
7
8
9
10
11
12
로그인 후 복사

다음과 같이 정렬됩니다.

1
10
11
12
2
3
4
5
6
7
8
9
로그인 후 복사

해결책:

정렬하는 방법에는 여러 가지가 있습니다. 다음을 포함한 올바른 영숫자 데이터:

1. 영숫자 정렬

이 방법은 BIN() 함수를 사용하여 영숫자 데이터를 이진수 표현으로 변환한 다음 정렬에 사용합니다.

SELECT *
FROM table
ORDER BY BIN(name) ASC, name ASC;
로그인 후 복사

2 . 자연 정렬

자연 정렬에는 숫자와 문자를 모두 고려하여 문자별로 값을 비교하는 작업이 포함됩니다. 이는 맞춤형 비교 기능을 사용하거나 해당 기능을 제공하는 외부 라이브러리를 활용하여 수행할 수 있습니다.

SELECT *
FROM table
ORDER BY name DESC; -- Using a customized comparison function
로그인 후 복사

3. 영숫자 값과 혼합된 숫자 값 정렬

숫자 및 영숫자 값의 혼합을 처리할 때 CAST() 함수를 사용하여 숫자 값을 부호 없는 정수로 변환할 수 있습니다. 정렬.

SELECT *
FROM table
ORDER BY CAST(name AS UNSIGNED), name;
로그인 후 복사

4. 길이 기반 정렬

이 방법은 각 값의 길이를 기준으로 데이터를 정렬하며, 짧은 값이 먼저 표시됩니다.

SELECT *
FROM table
ORDER BY LENGTH(name), name;
로그인 후 복사

참고: 구체적인 사용 방식은 특정 요구 사항과 MySQL 환경 내에서 사용 가능한 리소스에 따라 달라질 수 있습니다.

위 내용은 ORDER BY를 사용하여 MySQL에서 영숫자 데이터를 올바르게 정렬하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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