当前位置: 首页 > news >正文

mysql 对于null字段排序处理

最近遇到一个需求 ,需要对一个报表的多个字段进行多字段复杂条件排序

排序字段为NULL时

Mysql对于排序字段为NULL时,有自身默认的排序规则,默认是认为null 值 是无穷小

ELECT id,script_id,last_modified,live_count,next_show
FROM virtual_live_script
where 1 = 1and creator is null
ORDER BYlive_count desc,next_show asc,last_modified desc;

可以看到 next_show 为空的字段 的确按照 升序 是最小的
在这里插入图片描述如果想让 next_show 为 null的记录排在最后 应该怎么处理呢?可以在引入一个新的字段 比如sort 字段,排序的时候 对这个新的字段也排序,就可以实现上述逻辑,同样的思路 还可以对null 值字段进行特殊处理

SELECT id,script_id,last_modified,live_count,next_show,next_show is null as sort
FROM virtual_live_script
where 1 = 1and creator is nullORDER BY live_count desc,sort asc,next_show asc,last_modified desc;

在这里插入图片描述

还有一种不加辅助字段的方法,利用IFNULL 函数,这里给为空时间,指定一个值,只不过要在业务代码中要去除2030-01-01 00:00:00 这个,有点侵入性!

SELECT id,script_id,last_modified,live_count,ifnull(next_show,'2030-01-01 00:00:00') as tmp
FROM virtual_live_script
where 1 = 1and creator is nullORDER BY live_count desc,tmp asc,last_modified desc;

在这里插入图片描述

多条件复杂排序

对于多条件的复杂排序,可以使用case … when语句,类似如下思路


SELECT id,script_id,script_name,cover_url,last_modified,live_count,pre_count,end_count,status,next_show
FROM virtual_live_script
where 1 = 1and creator = :creator
order by live_count desc,CASEWHEN live_count = 0 AND next_show IS NULL THEN -1WHEN live_count = 0 AND pre_count > 0 THEN 0ELSE 0END desc,next_show asc,last_modified desc;

参考

Mysql排序字段为NULL如何排序
sort-by-start-date-desc-if-end-date-is-null-if-not-sort-by-end-date

http://www.lryc.cn/news/296228.html

相关文章:

  • NLP_语言模型的雏形 N-Gram 模型
  • mac电脑flutter环境配置,解决疑难问题
  • C++ bool 布尔类型
  • DC-7靶机渗透详细流程
  • 提速MySQL:数据库性能加速策略全解析
  • Flink实战六_直播礼物统计
  • Compose | UI组件(十五) | Scaffold - 脚手架
  • Vue-60、Vue技术router-link的replace属性
  • Hive与Presto中的列转行区别
  • 探讨CSDN等级制度:博客等级、原力等级、创作者等级
  • 2.8作业
  • 机器学习中常用的性能度量—— ROC 和 AUC
  • 微服务入门篇:Nacos注册中心(Nacos安装,快速入门,多级存储,负载均衡,环境隔离,配置管理,热更新,集群搭建,nginx反向代理)
  • 解决CORS错误(Spring Boot)
  • NLP入门系列—词嵌入 Word embedding
  • JUnit5单元测试框架提供的注解
  • ThinkPHP 中使用Redis
  • Go语言Gin框架安全加固:全面解析SQL注入、XSS与CSRF的解决方案
  • MySQL数据库基础与SELECT语句使用梳理
  • scikit-learn 1.3.X 版本 bug - F1 分数计算错误
  • Python面试题19-24
  • 《Django+React前后端分离项目开发实战:爱计划》 01 项目整体概述
  • 从零开始 TensorRT(4)命令行工具篇:trtexec 基本功能
  • 基于SpringBoot+Vue的校园博客管理系统
  • 基于 SpringBoot 和 Vue.js 的权限管理系统部署教程
  • Redis篇之集群
  • JUnit 5 注解总结与解析
  • CSS综合案例4
  • WifiConfigStore初始化读取-Android13
  • 【Spring源码解读!底层原理进阶】【下】探寻Spring内部:BeanFactory和ApplicationContext实现原理揭秘✨