
NULLの行を最下位にする場合は、下記のようなコードで解決できました。
select * from table order by
case when TEST is null then 0 else 1 end Asc
例)
NULL | 1
3 | 2
1 |→ 3
2 |NULL
これを、時間(HH:MM)をソートする時に、順番が思うように行きません。
3:20 | 1:10
1:10 |→ 9:10
9:10 | NULL
NULL | 3:20
上記のような順にソートされてしまいます。
1:10
3:20
9:10
NULL
の順にするには、何かよい方法はありませんでしょうか?よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
#なんだか元データに問題があるような木もするのですが…。
とりあえず、
select
case when 日付 is null then 0 else 1 end As Sortkey
,* from table order by
case when 日付 is null then 0 else 1 end Asc
を流してみて、Sortkey列にどのような値が出ますか?
あと、「日付」の型はDate型ですか?それとも別の型ですか?
この回答への補足
申し訳御座いませんでした。
khazad-leftyさんの御指摘通り、データに問題がありました。
下記の通りで思い通りにソートできました。原因は、NULLと""(空白)がデータにあり、頂いたコードですと、""が認識できなかったようです。私の不手際で御迷惑をお掛けいたしました。 今後ともよろしくお願い致します。 ありがとう御座います。
select * from テーブル order by case when 日付 is null then '2' when 日付 = '' then '1' else 0 end, 日付;
ご返信誠にありがとう御座います。
1. Sortkey列の値
1:10 → 1
3:20 → 1
9:10 → 1
NULL → 0
2. 日付の型は、NVARCHAR です。
以上、よろしくお願いします。
No.3
- 回答日時:
SQLCMD(バージョンによってはOSQL)で下記のようにやっても、NULLが
最後尾に出力されませんか?
create table tbl
(
dt nvarchar(5)
)
go
insert into tbl values ( NULL );
insert into tbl values ( N'01:10' );
insert into tbl values ( N'03:20' );
insert into tbl values ( N'09:10' );
go
select dt
from tbl
order by case when dt is null then 1 else 0 end, dt;
go
khazad-leftyさんの御指摘通り、データに問題がありました。
下記の通りで思い通りにソートできました。原因は、NULLと""(空白)がデータにあり、頂いたコードですと、""が認識できなかったようです。せっかく頂いたコードですが、勉強にさせて頂きました。ありがとう御座います。
select * from テーブル order by case when 日付 is null then '2' when 日付 = '' then '1' else 0 end, 日付;
No.1
- 回答日時:
select * from テーブル order by case when 日付 is null then 1 else 0 end, 日付;
で行けませんか。
申し訳御座いませんでした。
khazad-leftyさんの御指摘通り、データに問題がありました。
下記の通りで思い通りにソートできました。原因は、NULLと""(空白)がデータにあり、頂いたコードですと、""が認識できなかったようです。私の不手際で御迷惑をお掛けいたしました。 今後ともよろしくお願い致します。 ありがとう御座います。
select * from テーブル order by case when 日付 is null then '2' when 日付 = '' then '1' else 0 end, 日付;
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
日付
-
ここで「interval」は どんな働...
-
テーブルの最後(最新)のレコー...
-
SQLローダーCSV取込で、囲み文...
-
単一グループのグループ関数で...
-
Oracleで「文字が無効です」の...
-
レコードの登録順がおかしい
-
select文の実行結果に空白行を...
-
AccessのSQL文で1件のみヒット...
-
where句中のtrim関数について
-
タイトル行を固定してソートしたい
-
テーブルレーコードをソートし...
-
ハイフンの入ったデータの並べ替え
-
【PL/SQL】FROM区に変数を使う方法
-
ファイルの漢数字の順番につい...
-
OUTER JOIN とgroup by
-
並べ替えについて
-
トランザクションログを出力せ...
-
SQL*Loader Append
-
count関数の値をwhere句で使用...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
<SQL>重複しているデータの場合...
-
複数のテーブルから値を合計出...
-
最新の日付と2番目の日付のデー...
-
【ExcelVBA】入力された日付か...
-
LIKE検索で範囲指定の方法
-
項目以外の文字列は連結できま...
-
日付
-
Mysqlについて、どの程度の処理...
-
SQLで、同じ値が何回連続す...
-
検索を繰り返す?
-
日付
-
mysqlでunixtimeによる日付範囲...
-
MySQLにおける条件/公開日を指...
-
PHPとMYSQLを使用したデータベ...
-
日付検索で0001-01-01 00:00:00...
-
windows7のmysqlで今日の日付か...
-
型変換
-
効率の良いSQL文の書き方を教え...
-
SQLです教えてくださいお願いし...
-
日付や日時を格納する場合の型...
おすすめ情報