MySQLにてORDER BYで並べ替える際に空のカラムは後ろに持ってくる方法
MySQLにてORDER BYで並べ替える際に空のカラムの場合は後ろに持っていき、その上でID(通し番号)順に並べ替えたい。具体的には「空じゃないカラムのID順→空のカラムのID順」という順序に並べ替えたい。以下に対応方法をメモ。
テーブル構造
mysql> SHOW COLUMNS FROM `test_table`; +-------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+--------------+------+-----+---------+----------------+ | id | int | NO | PRI | NULL | auto_increment | | name | varchar(255) | NO | | NULL | | +-------+--------------+------+-----+---------+----------------+
データ内容
mysql> TABLE `test_table`; +----+--------+ | id | name | +----+--------+ | 1 | 山田 | | 2 | | | 3 | 鈴木 | | 4 | | | 5 | 田中 | +----+--------+
対応方法
SELECT *
FROM `test_table`
ORDER BY
CASE
WHEN `name` IS NULL THEN "2"
WHEN `name` = "" THEN "1"
else "0"
END,
`id` ASC;
+----+--------+
| id | name |
+----+--------+
| 1 | 山田 |
| 3 | 鈴木 |
| 5 | 田中 |
| 2 | |
| 4 | |
+----+--------+
nameカラムが空のデータを後ろに持っていき、その上でID順にソートされた。
関連記事
-
-
MySQLでINSERT時にオートインクリメントではないカラムに連番を登録する方法
MySQLでINSERT時にオートインクリメントではないカラムに連番を登録したい ...
-
-
MySQLで文字列を置換する方法
MySQLで文字列の置換を行いたかった。以下に方法をメモ。 目次1 ...
-
-
MySQLでカラム内容によって条件分岐させたい場合の対応方法
MySQLでカラムの内容によって条件を分岐させたかった。またPHPで処理するので ...
-
-
WordPressサイトのロードアベレージが高い際の対応方法
あるWordPressサイトのロードアベレージが先月ぐらいまでは通常0.5前後で ...
-
-
MySQLでテーブルとデータの複製(コピー)する方法
MySQLでテーブルとデータを複製したかった。ダンプとかではなく、簡単なSQL文 ...