MySQL で数値を含む文字列列を昇順に並べ替えるにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-27 16:07:29
オリジナル
540 人が閲覧しました

How to Sort String Columns Containing Numbers in Ascending Order in MySQL?

SQL での数値を含む文字列カラムのソート

数値を含む文字列カラムをソートする場合、デフォルトの MySQL ソート アルゴリズムは文字の後に数値を配置します。これは、常に望ましい動作であるとは限りません。

問題:

数値を含む次の文字列列を昇順に並べ替えます:

name
a 1
a 12
a 2
a 3

期待される動作結果は次のとおりです:

name
a 1
a 2
a 3
a 12

SQL による解決策:

列パターンが常に "WORD space NUMBER" であると仮定すると、次の SQL クエリを使用できます:

<code class="sql">SELECT *
FROM table
ORDER BY CAST(SUBSTRING(column, LOCATE(' ', column) + 1) AS SIGNED);</code>
ログイン後にコピー
  • CAST(): 部分文字列 (数値) を数値に変換します。
  • LOCATE(' ', column): スペース文字の位置を検索します。
  • SUBSTRING(): 数値を含む部分文字列を抽出します。

または、SUBSTRING_INDEX:

<code class="sql">ORDER BY SUBSTRING_INDEX(column, " ", 1) ASC, CAST(SUBSTRING_INDEX(column, " ", -1) AS SIGNED);</code>
ログイン後にコピー

このクエリは SUBSTRING_INDEX を使用して文字列の単語部分と数値部分を個別に抽出し、それに応じて並べ替えます。

説明:

この解決策は、文字列内のスペース文字の後の部分文字列には常に数字が含まれるという事実に基づいています。この部分文字列を数値に変換すると、接頭辞の文字を無視して、列を数値的に並べ替えることができます。

注:

文字列列が " に続いていない場合は、 WORD space NUMBER" パターンの場合、目的の並べ替え結果を得るために追加のロジックまたは文字列操作関数が必要になる場合があります。

以上がMySQL で数値を含む文字列列を昇順に並べ替えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!