您的位置:首页 > 数据库 > Oracle

ORACLE自定义顺序排序

2014-11-05 14:22 435 查看
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放最后,其它项则按其它排序方式(一般按正常的升序),可看作同一列有两种排序方式,那么可以这样:

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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: