在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。

相关推荐
Elastic 中国社区官方博客9 小时前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660219 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
懂懂tty9 小时前
CRA 迁移 Rspack(实战)
前端·架构
qq_3721542310 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
小码哥_常10 小时前
Kotlin 助力 Android 启动“大提速”
前端
GreenTea11 小时前
AI 时代,工程师的不可替代性在哪里
前端·人工智能·后端
_下雨天.11 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y11 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python
Jagger_11 小时前
能不能别再弄低代码害人了
前端
2401_8877245011 小时前
CSS如何让表单在手机端友好展示_利用Flexbox实现堆叠排版
jvm·数据库·python