ORACLE自定義順序排序-轉

ORACLE能夠藉助DECODE函數,自定義順序排序:函數

複製代碼
select * from (
    select 'Nick' as item from dual
    union all
    select 'Viki' as item from dual
    union all
    select 'Glen' as item from dual
    union all
    select 'Robin' as item from dual
    union all
    select 'Total' as item from dual
) pre_tab
order by decode(item, 'Viki', 1, 'Glen', 2, 'Robin', 3, 'Nick', 4, 'Total', 99);
複製代碼

 

另外,在Report開發中,常須要將Total放最後,其它項則按其它排序方式(通常按正常的升序),可看做同一列有兩種排序方式,那麼能夠這樣:spa

複製代碼
select * from (
    select 'Nick' as item from dual
    union all
    select 'Viki' as item from dual
    union all
    select 'Glen' as item from dual
    union all
    select 'Robin' as item from dual
    union all
    select 'Total' as item from dual
) pre_tab
order by decode(item, 'Total', 2, 1), item;
複製代碼
相關文章
相關標籤/搜索