用列位置来代替列名
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