博客
关于我
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/

你可能感兴趣的文章
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>