Oracle 查询优化 : 对查询结果排序

用列位置来代替列名
SELECT A,B,C FROM DUAL ORDER BY C
==
SELECT A,B,C FROM DUAL ORDER BY 3
优点:更改列名后 不需要修改 ORDER BY 条件 (该方法只可在ORDER BY子句中使用,其他地方不可使用)
按多个字段排序
SELECT A,B,C FROM DUAL ORDER BY C ASC,B DESC
ASC:升序
DESC:降序
TRANSLATE字符串替换:

TRANSLATE(expr,from_string,to_string)
from_string,to_string 以字符为单位,对应字符一一替换
若to_string为‘’ , 则返回NULL
eg:TRANSLATE(‘123 你好’,‘123’,‘’) 返回NULL
若to_string对应位置无字符,则from_string对应字符会被删除
eg:TRANSLATE(‘123 你好’,‘123’,‘1’) 返回1你好

处理排序空值:

NULLS FIRST \ NULLS LAST

根据条件取列中不同的值进行排序:

例如:取工资1000 - 2000的排在前面

SELECT 
	 CASE WHEN SAL >=1000 ANN <=2000 THEN 1
	 ELSE 2
	 WITH CASE
FROM DUAL
ORDER BY CASE
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值