ホームページ >データベース >mysql チュートリアル >SQL Server で英数字の値が混在する VARCHAR 列を自然に並べ替える方法
SQL Server での英数字の値が混在する VARCHAR 列の並べ替え
データベース テーブルには、文字と数字の組み合わせを格納できる VARCHAR 列が含まれる場合があります。数字。この列を並べ替えるときは、数値以外のフィールドのアルファベット順を維持しながら、数値を区切って自然に並べ替えることが望ましいことがよくあります。
問題:
どうすればよいですか? SQL Server で文字と数字の両方を含む VARCHAR 列を、数字が数値順に並べ替えられ、文字が並べ替えられるように並べ替えるとします。
解決策:
これを実現するには、IsNumeric 関数と Replicate 関数を組み合わせたメソッドを使用します。 IsNumeric 関数は文字列が数値かどうかを確認し、Replicate 関数は指定された数の文字を文字列の先頭に追加します。
クエリの例を次に示します。
SELECT MyColumn FROM MyTable ORDER BY CASE IsNumeric(MyColumn) WHEN 1 THEN Replicate('0', 100 - Len(MyColumn)) + MyColumn ELSE MyColumn END
このクエリでは、CASE 式は、MyColumn 列の値が数値かどうかをチェックします。その場合、Replicate 関数は、すべての数値が同じ長さ (この例では 100) になるように、文字列に十分な数の先行ゼロを追加します。これにより、数値順にソートされることが保証されます。
数値以外の値の場合、ELSE 句は単純に元の値を返し、アルファベット順を維持します。
Replicate 関数の値 100 をベースに調整します。列内の数値の最大長について。
以上がSQL Server で英数字の値が混在する VARCHAR 列を自然に並べ替える方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。