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')
相关推荐
java1234_小锋1 分钟前
LangChain4j 开发Java Agent智能体- 整合SpringBoot4
java·开发语言·langchain4j
basketball6164 分钟前
C++进阶:3. unique_ptr 现代C++内存管理的基石
java·jvm·c++
zzqssliu10 分钟前
跨境代购系统的物流和通知模块重构思考:从设计模式到生产落地
java·设计模式·重构
appearappear13 分钟前
一句sql 根据明细数据状态,精确更新一个主单主状态
java
许彰午16 分钟前
04_Java数组操作全解
java·开发语言·python
AIGS00117 分钟前
生产运营三大瓶颈,工业AI怎么破局?
java·人工智能·人工智能ai大模型应用
码不停蹄的玄黓17 分钟前
Java 线程池 execute() 和 submit() 对比
java·开发语言
方也_arkling25 分钟前
【Java-Day19】集合1(Collect单列集合)
java·开发语言
方也_arkling38 分钟前
【Java-Day19】集合3 List中常见的方法和5种遍历方式
java·开发语言