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

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

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

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Q&A

解決済

1回答

277閲覧

MariaDBでソートしたい

退会済みユーザー

退会済みユーザー

総合スコア0

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

0グッド

0クリップ

投稿2018/05/02 01:42

編集2018/05/02 01:46

質問

以下の結果が出力できるSQLを書きたいです。

txt

11a 21b 31c 41g 52a 62b 72e 810a 910b

試したこと1

以下のSQLの場合、10a, 10bが上に来てしまいます。

sql

1SELECT id from dummy order by id

txt

110a 210b 31a 41b 51c 61g 72a 82b 92e

試したこと2

以下のSQLの場合1gが上に来てしまいます。1gが1と変換される為です。

sql

1SELECT id, (CONV(id, 16, 10) + 0) 2FROM dummy 3ORDER BY (CONV(id, 16, 10) + 0)

idの値について

[0-9a-z]です。

テーブル構成

sql

1CREATE TABLE IF NOT EXISTS `dummy` ( 2 `id` varchar(3) DEFAULT NULL 3) ENGINE=InnoDB DEFAULT CHARSET=utf8; 4 5INSERT INTO `dummy` (`id`) VALUES 6 ('1a'), 7 ('1b'), 8 ('1c'), 9 ('2a'), 10 ('2b'), 11 ('2e'), 12 ('10a'), 13 ('10b'), 14 ('1g'); 15

バージョン

10.2.12-MariaDB

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

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

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

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

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

guest

回答1

0

ベストアンサー

order by length(id), id

でいかが?

投稿2018/05/02 01:55

Orlofsky

総合スコア16415

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

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

退会済みユーザー

退会済みユーザー

2018/05/02 02:08

ありがとうございます。 できました。 文字列長を考慮すればよかったのですね。 SELECT id FROM dummy order by length(id), id
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問