在sql中影响排序,但不改变字段值的方法

在order by 后面使用case ... when ... else ... end:

sql 复制代码
select sn, eos_date from device_table
ORDER BY 
	case 
		when eos_date = '1970-01-01' then null
		else eos_date 
		end
		asc
		nulls last

上面的sql中,order by后面不是某个字段,而是一个条件表达式 case ... when ... else ... end.

表示当字段eos_date = '1970-01-01'时,则表示该行数据排序的值为null,其他情况为eos_date的原始值。

但是select到的值,仍然是eos_date的原始值,当eos_date = '1970-01-01',select到的值,仍然是'1970-01-01',而不是null。

相关推荐
一名机电研究生2 分钟前
电机驱动系统智能监测与故障预测技术指南:构建数据驱动的预防性维护体系
python·sql·诊断预测
mit6.82419 分钟前
sql窗口函数
数据库
踢球的打工仔19 分钟前
typescript-类
前端·javascript·typescript
天天打码34 分钟前
Svelte-无虚拟DOM、极致性能的现代高性能Web开发框架!
前端·node.js·vue·svelte
0思必得041 分钟前
[Web自动化] Selenium元素定位
前端·python·selenium·自动化·html
七七七七071 小时前
【Redis】Ubuntu22.04安装redis++
数据库·redis·缓存
拾起零碎1 小时前
U8/对比一级科目,快速判断需要调整的报表
sql
EEEzhenliang1 小时前
CSS知识概括、总结
前端·css
子非鱼9211 小时前
MyBatisPlus快速上手
数据库·spring boot·mybatisplus
DBA小马哥1 小时前
从传统数据库到金仓数据库:时序数据迁移的挑战与解决方案
数据库·时序数据库·dba