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')
相关推荐
信徒_4 分钟前
ID 生成技术选型
java
a8a30214 分钟前
Laravel8.x新特性全解析
java·spring boot·后端
XiYang-DING21 分钟前
【Java EE】CAS(Compare And Swap)
java·开发语言·java-ee
白露与泡影28 分钟前
Spring Boot 完整流程
java·spring boot·后端
空中海41 分钟前
第二章:Maven进阶篇 — 依赖管理与构建生命周期
java·maven
xun-ming1 小时前
AI时代Java程序员自救手册
java·开发语言·人工智能
DavidSoCool1 小时前
GB28181 PTZCmd 完整指令对照表(8 位 16 进制)+ 详细注释 + 使用说明
java·sip·gb28181
张健11564096481 小时前
C++访问控制与友元
java·开发语言·c++
Sam_Deep_Thinking1 小时前
中小团队需要一个资源微服务
java·微服务·架构
Thanks_ks1 小时前
透过 Copy-On-Write 机制:理解并发编程中的性能与一致性权衡
java·多线程·并发编程·底层原理·写时复制·copyonwrite·性能优