use*_*934 3 sql postgresql postgresql-9.2
我有一个表,其中有一组带有开始标签和结束标签的路线.每行都有一列"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
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4734 次 |
最近记录: |