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...

相关推荐
枷锁—sha5 分钟前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞18 分钟前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean18 分钟前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_5500246321 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦22 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_999936 分钟前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7651 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码1 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean1 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
小Tomkk2 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase