[英]Conditional Order By
我有一個表,其中有一組帶有開始標簽和結束標簽的路線。 每行都有一列“progres”,它是應用全局“order by”子句的列,最后是一個選擇列,用於指示必須訂購哪些標簽類型(奇數,偶數或全部)。 如果LabelStart> LabelEnd =>由ASC訂購,否則由DESC訂購
例如,這里是路線路徑
Routes ID RouteID, Progres, LabelStart, LabelEnd Type 1 1 5 1 21 O 2 1 10 10 2 E 4 2 15 2 25 A 5 3 20 1 11 O 6 3 22 4 10 E 7 4 30 5 11 O 8 4 31 2 12 E
這里是屬於路線的點數
Points PoinID RouteID, Label 1 1 3 2 1 2 4 1 1 5 1 8 6 1 5 7 1 6 8 1 9 9 1 21 10 1 10 11 1 11 12 2 1 13 2 2 14 2 12 15 2 3 16 2 25 17 2 14 ...
我需要的是一個表,其中所有點都由Routes Proges全局排序,按Even,Odd或All分類,最后由ASC訂購,如果LabelStart> LabelEnd,則由DESC排序。 結果應該是:
ID RouteID, PointID 1 1 4 2 1 1 4 1 6 5 1 8 6 1 11 7 1 9 8 1 10 9 1 5 10 1 7 11 1 2 12 2 13 13 2 15 ...
select
row_number() over() id, *
from (
select
r.routeid,
p.pointid,
label,
type,
labelstart,
labelend
from
route r
inner join
point p on p.routeid = r.routeid
where
r.type = 'E' and p.label % 2 = 0
or
r.type = 'O' and p.label % 2 != 0
or
r.type = 'A'
order by
r.routeid, r.progres, r.id,
case labelstart < labelend
when true then label
else label * - 1
end
) s
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.