sql 语句中case when 习惯性错误

使用场景:在一些小的需求,为了一次性将数据统计到位,在代码中少出现一些转化的代码,习惯性的在sql语句中加一些判空、枚举之类的进行转化,尤其是在现场数据治理的时候,比方说现场要导出一些基础台账数据等,这个时候就可以很方便的提供一条sql语句(开发过程一般是不建议在sql语句中处理这种转化逻辑的,严格在定义枚举在转化层进行处理)

常规写法:

sql 复制代码
case t1.is_enable
        when 1 then 0
        when 0 then 1
        when 2 then 2
        end as isEnable

错误写法:

sql 复制代码
case t1.start_date
 when is null then ''
 else FROM_UNIXTIME(t1.start_date/1000, '%Y-%m-%d %H:%i:%s')
 end

正确写法:

sql 复制代码
case
	when t1.invalid_end_date is null then ''
	else FROM_UNIXTIME(t1.invalid_end_date/1000, '%Y-%m-%d %H:%i:%s')
	end as invalidEndTime

总结:

简单 CASE 形式:CASE column WHEN value THEN...

搜索 CASE 形式:CASE WHEN condition THEN...

第二种写法不会报错是因为它正确使用了简单 CASE 形式:

t1.is_enable 是列名

1, 0, 2 是具体的值

这种形式用于直接比较列的值

第二种写法 is null 是一个条件判断,但却使用了简单 CASE 的形式,导致语法错误。

总结:

当需要比较列值是否等于某个特定值时,使用: CASE 列名 WHEN 值 THEN...

当需要判断条件(如 IS NULL,>,<,LIKE 等)时,必须使用: CASE WHEN 条件 THEN...

相关推荐
IvorySQL11 分钟前
PostgreSQL 技术日报 (3月28日)|零停机补丁、约束新特性、性能避坑全收录
数据库·postgresql·开源
smchaopiao13 分钟前
数据库优化技巧详解:从LIMIT到索引的提升策略
数据库·oracle
清水白石00818 分钟前
Python 编程全景解析:四大核心容器的性能较量、语义之美与高阶实战
开发语言·数据库·python
菜菜小狗的学习笔记18 分钟前
黑马程序员Redis--实战篇(黑马点评)
数据库·redis·缓存
2401_8785302118 分钟前
深入理解Python的if __name__ == ‘__main__‘
jvm·数据库·python
zz-zjx20 分钟前
harbor使用外置db,redis,存储(minio)通过pigsty安装(单机)
数据库·redis·缓存
踩着两条虫32 分钟前
VTJ.PRO 在线应用开发平台的数据库与基础设施
数据库·架构·nestjs
!停42 分钟前
C++入门基础—类和对象3
java·数据库·c++
llilian_161 小时前
ptp从时钟 ptp授时模块 如何挑选PTP从时钟授时协议模块 ptp从时钟模块
数据库·功能测试·单片机·嵌入式硬件·测试工具
municornm1 小时前
【MySQL】to_date()日期转换
数据库·mysql