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でtime型データからint型データの減算を行い、減算後のデータで条件検索する方法
MySQLでtime型データからint型データの減算を行い、減算後のデータを検索 ...
-
-
MySQLのTEMPORARY TABLE(テンポラリテーブル)で高速化を図る方法
MySQLで5000万件ぐらいデータが入っているテーブルから日本語検索しないとい ...
-
-
MySQLでJOINの高速化
JOINで無茶苦茶悩んだのでメモ。やりたかった事は、MySQLで テーブルAには ...
-
-
phpmyadminからプロセスの停止
重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...
-
-
MySQLでdatetime型のカラムをdate型やtime型に変換して検索する方法
MySQLでdatetime型のカラムがあり、そちらをdate型やtime型に変 ...