問題:
MySQL 並べ替えルーチンは、保存されているバージョン番号に対して希望の並べ替え順序を提供しない場合がありますvarbinary(300) として。並べ替えでは最大 20 桁を考慮し、次のような結果を生成する必要があります:
1.1.2 1.2.3.4 2.2 3.2.1.4.2 3.2.14 4 9.1
解決策:
次のクエリで INET_ATON 関数を使用します:
SELECT version_number FROM table ORDER BY INET_ATON(SUBSTRING_INDEX(CONCAT(version_number,'.0.0.0'),'.',4))
この手法は、IP アドレスを整数に変換する INET_ATON の機能を利用します。バージョン番号に .0.0.0 を追加し、SUBSTRING_INDEX を使用して最初の 4 つのコンポーネントのみを抽出することにより、バージョン番号を同等の整数表現に効果的に変換します。
追加の考慮事項:
以上がMySQL のバージョン番号を正しく並べ替えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。