dポイントプレゼントキャンペーン実施中!

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
の順にするには、何かよい方法はありませんでしょうか?よろしくお願い致します。

A 回答 (3件)

#なんだか元データに問題があるような木もするのですが…。



とりあえず、
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, 日付;

補足日時:2008/03/26 09:30
    • good
    • 0
この回答へのお礼

ご返信誠にありがとう御座います。

1. Sortkey列の値
1:10 → 1
3:20 → 1
9:10 → 1
NULL → 0

2. 日付の型は、NVARCHAR です。

以上、よろしくお願いします。

お礼日時:2008/03/23 16:57

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
    • good
    • 0
この回答へのお礼

khazad-leftyさんの御指摘通り、データに問題がありました。
下記の通りで思い通りにソートできました。原因は、NULLと""(空白)がデータにあり、頂いたコードですと、""が認識できなかったようです。せっかく頂いたコードですが、勉強にさせて頂きました。ありがとう御座います。

select * from テーブル order by case when 日付 is null then '2' when 日付 = '' then '1' else 0 end, 日付;

お礼日時:2008/03/26 09:32

select * from テーブル order by case when 日付 is null then 1 else 0 end, 日付;


で行けませんか。

この回答への補足

お返事ありがとうございます。 
せっかくお返事を頂いたのですが、依然NULLが先頭にきてしまいます。

補足日時:2008/03/23 06:36
    • good
    • 0
この回答へのお礼

申し訳御座いませんでした。
khazad-leftyさんの御指摘通り、データに問題がありました。
下記の通りで思い通りにソートできました。原因は、NULLと""(空白)がデータにあり、頂いたコードですと、""が認識できなかったようです。私の不手際で御迷惑をお掛けいたしました。 今後ともよろしくお願い致します。 ありがとう御座います。

select * from テーブル order by case when 日付 is null then '2' when 日付 = '' then '1' else 0 end, 日付;

お礼日時:2008/03/26 09:30

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!