質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

Q&A

解決済

1回答

1259閲覧

MySQLでLikeを駆使して任意の並び替えをしたい

1namin

総合スコア7

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

0グッド

1クリップ

投稿2018/04/14 08:34

前提・実現したいこと

MySQLにて
1F,2F,3F,4F,5F,6F,7F,8F,9F,10F,11F,12F,M2F,M4F
のような値の入った単一カラムにて
1F,2F,M2F,3F,4F,M4F,5F,6F,7F,8F,9F,10F,11F,12F
のように「M + 数字F」の値を数字の羅列間に挿入してソートをしたいです。

発生している問題

Mと数字のカラムを分ければ実現できそうですが、
既存システムへの影響が大きそうなのでカラムの追加をすることはできません。

考えたSQL文

select *
case when column like '%1F%' then 1
case when column like '%2F%' then 2
case when column like '%3F%' then 3
case when column like '%4F%' then 4
・・・
case when column like '%9F%' then 9
else 100 END
As Sort_id
order by Sort_id asc;

では12Fが上に来てしまい思ったようにいきませんでした。
上限が分かれば愚直にそこまで書き並べるということもできそうですが。。

試したこと

試したわけではないですが
書いていて思ったのはMと数字Fを二つのカラムに分けてselectする方法があれば
別カラムでデータが入っている時と同様のソートが出来るのではと思いました。

補足情報(FW/ツールのバージョンなど)

MySQL 5.6.16

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

sql

1SELECT 2 `FLOOR` 3 , CASE 4 WHEN `FLOOR` REGEXP 'M[0-9]+F' THEN REPLACE(REPLACE(`FLOOR`, 'M', ''), 'F', '') + 0.5 5 WHEN `FLOOR` REGEXP '[0-9]+F' THEN REPLACE(`FLOOR`, 'F', '') 6 END AS `floor_order` 7FROM 8 sample 9ORDER BY floor_order

投稿2018/04/14 08:50

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

1namin

2018/04/14 08:59

なるほど!データベースの値からいらない文字を消していくことでソートに利用するアイデア 自分では思いつかなかったです。 REPLACEすることでこんなこともできるのですね! まだまだ勉強不足です、ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問