MySQL 버전 번호 정렬
MySQL에서 버전 번호 정렬은 어려울 수 있으며, 특히 1.1.2, 9.1과 같은 복잡한 형식을 처리할 때 더욱 그렇습니다. 및 2.2. 버전_번호별 표준 순서 구문을 사용하면 잘못된 결과가 나오는 경우가 많습니다.
이 문제를 해결하려면 INET_ATON 함수와 관련된 영리한 해결 방법을 사용할 수 있습니다.
SELECT version_number FROM table ORDER BY INET_ATON(SUBSTRING_INDEX(CONCAT(version_number,'.0.0.0'),'.',4))
이 트릭은 INET_ATON을 사용하여 변환합니다. 버전 번호를 IP 주소 형식으로 변환하여 값을 숫자로 정렬할 수 있습니다. 특히, 각 행에 최소한 4개의 부분이 있는지 확인하기 위해 '0.0.0'을 추가한 다음 SUBSTRING_INDEX를 사용하여 처음 4개의 부분만 추출하여 정렬합니다.
이 해결 방법은 원하는 정렬 순서를 제공하지만 열에 대한 함수 호출이 포함되어 인덱스를 사용할 때보다 정렬 프로세스가 느려질 수 있다는 점에 유의해야 합니다.
더 복잡한 버전 번호 형식의 경우 전문가가 권장하는 또 다른 접근 방식은 버전 번호의 각 부분에 대해 별도의 열을 만들고 대신 해당 열을 정렬하는 것입니다. 이렇게 하면 정렬 시 인덱스를 활용하고 더 나은 성능을 얻을 수 있습니다.
위 내용은 MySQL에서 복잡한 버전 번호를 정렬하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!