Trafodion 自定义排序

本文介绍如何在SQL查询中使用DECODE函数或CASEWHEN来实现自定义排序规则,通过实例展示了如何按照特定顺序而非默认字母或数字顺序进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家都知道在SQL语句中,我们一般使用ORDER BY 来排序SQL输出的结果,可以使用ASC(默认)指定升序排列,DESC指定降序排列,比如

>>select a,b from test order by a asc, b asc;

A            B
-----------  ----------

          1  A
          2  B
          2  C
          3  D
          3  E
          3  F

--- 6 row(s) selected.
>>select a,b from test order by a desc, b desc;

A            B
-----------  ----------

          3  F
          3  E
          3  D
          2  C
          2  B
          1  A

--- 6 row(s) selected.

假如我们希望排序并不按照字母顺序或者数字大小顺序来排序,而是根据自定义的规则排序结果应该怎么实现,可以结合DECODE函数或CASE WHEN实现,关于DECODE的用法请参考: http://trafodion.incubator.apache.org/docs/2.1.0/sql_reference/index.html#decode_function , DECODE与CASE WHEN可以实现相同的功能。

举例如下,结果集有’play’,’collect’及’order’,默认情况下使用ORDER BY的结果应该是’collect’,’order’,’play’,但如果希望按照’play’,’collect’,’order’排序应该像下面这样实现,

>>select t.a,decode(t.a,'play',1,'collect',2,'order',3,4) as rownum
from (
select 'play' as a from dual
union all
select 'collect' as a from dual
union all
select 'order' as a from dual) as t order by rownum;+>+>+>+>+>+>

A        ROWNUM
-------  ------

play          1
collect       2
order         3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据源的港湾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值