flink Unsupported operand types: IF(boolean, NULL, String)

问题:业务方存储了NULL 字符串,需要处理为 null

sql 复制代码
select if('a'='null',null,'a');

结果遇到了 Unsupported operand types: IF(boolean, NULL, String),根据报错反馈,很明显应该是没有对 null 自动转换(Spark 是会自动转的)

源码:

if 的源码我以前看过,就是calcyte自动生成的,在org.apache.flink.table.planner.codegen.calls 的 IfCallGen 类

确实没办法了,只能

sql 复制代码
select if(a='null',cast(null as string),'a')
相关推荐
左左右右左右摇晃2 分钟前
Java笔记——IO
java·开发语言·笔记
萍萍学习2 分钟前
蓝桥杯JAVA-3
java·职场和发展·蓝桥杯
西野.xuan5 分钟前
内存布局(堆vs栈)一篇详解!!
java·数据结构·算法
无心水5 分钟前
时间处理工程落地指南:数据库/日志/API/定时任务
java·大数据·数据库·日志·分布式架构·utc·gmt
Byron__6 分钟前
HashSet/LinkedHashSet/TreeSet 原理深度解析
java·开发语言
小陈工1 小时前
2026年3月24日技术资讯洞察:边缘AI商业化,Java26正式发布与开源大模型成本革命
java·运维·开发语言·人工智能·python·容器·开源
haibindev1 小时前
把近5万个源文件喂给AI之前,我先做了一件事
java·前端·c++·ai编程·代码审计·架构分析
yymboss1 小时前
【JavaEE】Spring Boot 项目创建
java·spring boot·java-ee
sxhcwgcy1 小时前
快速在本地运行SpringBoot项目的流程介绍
java·spring boot·后端
xiaomo22491 小时前
javaee-多线程进阶
java·开发语言