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')
相关推荐
JWASX5 分钟前
【RocketMQ 生产者和消费者】- 事务源码分析(1)
java·rocketmq·java-rocketmq
AlunYegeer1 小时前
JAVA,以后端的视角理解前端。在全栈的路上迈出第一步。
java·开发语言·前端
DFT计算杂谈2 小时前
自动化脚本一键绘制三元化合物相图
java·运维·服务器·开发语言·前端·python·自动化
2301_771717212 小时前
Spring Boot 自动配置核心注解
java·spring boot·mybatis
小Y._2 小时前
面试被问synchronized锁升级,这5个问题答不上来直接挂!
java
姚青&3 小时前
测试技术体系
java·python
渣渣盟3 小时前
Flink并行数据源:ClickSource实现详解
flink·scala
南境十里·墨染春水3 小时前
C++日志 2——实现单线程日志系统
java·jvm·c++
渣渣盟3 小时前
Flink单流转换算子实战解析
flink·scala