这篇文章主要讲解了oracle用decode函数或CASE-WHEN实现自定义排序的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。1 问题对sql排序,只要在order b
这篇文章主要讲解了oracle用decode函数或CASE-WHEN实现自定义排序的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
1 问题
对sql
排序,只要在order by
后面加字段就可以了,可以通过加desc
或asc
来选择降序或升序。但排序规则是默认的,数字、时间、字符串等都有自己默认的排序规则。有时候需要按自己的想法来排序,而不是按字段默认排序规则。
比如字段值为英文字段:Monday
、Tuesday
、Wednesday
等,如果按字段默认排序规则就为:
Friday
Monday
Saturday
Sunday
Thursday
Tuesday
Wednesday
实际我需要的是:
Monday
Tuesday
Wednesday
Thursday
Friday
Saturday
Sunday
2 decode函数
通过decode
函数可以实现,如下:
select * from table_date
order by
decode(DateStr,
'Monday',1
'Tuesday',2
'Wednesday',3
'Thursday',4
'Friday',5
'Saturday',6
'Sunday',7,
0);
--结束END--
本文标题: Oracle用decode函数或CASE-WHEN实现自定义排序的方法
本文链接: https://www.lsjlt.com/news/43290.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-29
2024-04-28
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0