SQL查询和优化(三)

给查询结果排序

SELECT empno,ename,hredate FROM emp WHERE deptno=10 ORDER BY HIREDATE ASC;
也可以这样写
SELECT empno,ename,hredate FROM emp WHERE deptno=10 ORDER BY 3 ASC;
按第三列排序的意思

多字段排序(部门编号升序,工资降序)

SELECT empno, deptno,sal,ename,job FROM emp ORDER BY 2 ASC,3 DESC;

TRANSLATE
语法格式:TRANSLATE( expr, from_string , to_string )

SELECT TRANSLATE ('ab 你好 bcdefg','abcdefg','1234567')AS NEW_STR FROM DUAL;
输出结果为: 12你好234567

处理排序空值 用关键字 NULLS FIRST 和 NULLS LAST。

SELECT empno, deptno,sal,ename,job FROM emp ORDER BY 3 NULLS FIRST;

根据条件取不同的列中的值来排序
比如:领导对工资在5000到8000之间的员工更感兴趣,要求把这个范围的员工排在前面优先查看

SELECT 
    empno AS 编号,
    ename AS 姓名,
    sal AS 工资 
FROM emp WHERE deptno=10
ORDER BY 
    CASE
       WHEN sal>=5000 AND sal<=8000 THEN 1
       ELSE 2
    END,3;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值