博客
关于我
sql 语句系列(行与列处理)[八百章之第一章]
阅读量:408 次
发布时间:2019-03-06

本文共 479 字,大约阅读时间需要 1 分钟。

排序时对null进行处理

比如说:

select * from EMP order by COMM

我需要对红框部分进行desc处理,也就是从大到小排列。

解析:

重点是如何让null独立出去。

select * from (select *,case when COMM is null then 0 else 1 end as COMMISNULL from EMP )xorder by COMMISNULL,COMM desc

解法:单独列出一列把null独立出去。

注意null的判断是 is而不是等于号

依据条件逻辑动态调整排序项

比如说:

select * from EMP

我希望的是:如果job 是SALESMAN的话,那么按照COMM排序,否则SAL 排序

解法:

在上面一个例子中,我们排行是通过排除某些行,对另外一个行进行处理。

而我们这个例子是针对列的,如果是针对列的那么更为简单。

select *

from EMP
order by case when JOB='SALESMAN' then COMM else SAL end

转载地址:http://bcskz.baihongyu.com/

你可能感兴趣的文章
NetScaler MPX Gateway Configuration
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
netstat kill
查看>>
netstat命令用法详解
查看>>
Netstat端口占用情况
查看>>
Netty 4的内存管理:sun.misc.Unsafe
查看>>
Netty channelRegistered\ChannelActive---源码分析
查看>>
Netty NIO transport && OIO transport
查看>>
netty php,netty
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Vue过渡 & 动画---vue工作笔记0014
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty 的 Handler 链调用机制
查看>>
Netty 编解码器和 Handler 调用机制
查看>>
Netty 编解码器详解
查看>>
Netty 解决TCP粘包/半包使用
查看>>
Netty 调用,效率这么低还用啥?
查看>>