ホームページ > データベース > mysql チュートリアル > MySQL のバージョン番号を正しく並べ替えるにはどうすればよいですか?

MySQL のバージョン番号を正しく並べ替えるにはどうすればよいですか?

Patricia Arquette
リリース: 2024-11-07 19:33:02
オリジナル
283 人が閲覧しました

How Can I Sort MySQL Version Numbers Correctly?

MySQL バージョン番号の並べ替え

問題:

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート