mysql根据某个字段降序排序,并且null值排在前面

在我们处理实际应用场景的时候经常会遇到按某个字段的需求,通常我们使用order by xxx字段 desc进行降序排序可以处理很多场景。

但是在工作中我遇到这么个场景,我新增了一条数据,但是real_online_time在新建的时候是空的,需要后期填写,而在展示列表中要求根据real_online_time排序。如果直接使用order by real_online_time desc,我们新建的那条数据就会排到最后(因为新建数据该字段值为null)。

在oracle中可以使用order by real_online_time desc nulls first解决,但是mysql却没有这个函数,在mysql中可以使用ORDER BY IF( ISNULL( real_online_time ), 0, 1 ),real_online_time DESC 解决

完整代码:

SELECT
	id,real_online_time
FROM
	apollo_deploy_version_log 
WHERE
	is_deleted = 'n' 
ORDER BY
IF( ISNULL( real_online_time ), 0, 1 ),
	real_online_time DESC 

效果如下:

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值