sql on条件判断是要注意null值

我是因为用了merge into语法,然后on条件中判断的字段是可配置的,这就导致了,有时候判断条件多的情况下,判断的字段会碰到有null值的情况,如果on两边的字段都是null,null和null对比就会导致结果为false,采取的操作就全都是insert了,碰到这种数据,就永远都不会走到更新逻辑了。

解决方案

使用COALESCE函数:COALESCE函数用于返回一组表达式中的第一个非NULL值,将NULL值替换为其他非NULL值。例如:

sql 复制代码
MERGE INTO target_table AS T
USING source_table AS S
ON (COALESCE(T.column_name, '') = COALESCE(S.column_name, ''))
WHEN MATCHED THEN
    -- 更新或插入操作
WHEN NOT MATCHED THEN
    -- 插入操作

总结

以上方案是可以用,但是存在一个问题时,空字符串可以兼容大部分的类型默认值,但是要是类型是数字的话,那么sql语句就会报错了。所以建议要是字段是数字类型的话,要么就在建库时给一个默认值,比如0,但是如果业务上要求这个字段null值也是有含义的,那么在采用上述方案处理时,就需要对字段的类型做一个判断,如果是数字,就默认值就不能用'',而是得用0,保证sql不报错且能匹配到数据,因为我这边做的是可配置的,所以字段类型也是允许用户维护的,因此我拿到类型是比较容易的,相反,要是on的字段是不可配置的,是固定的,那么sql写死就好了,字段该是啥类型,该写啥默认值,一开始就能确定了。

相关推荐
曹轲恒6 分钟前
SpringBoot配置文件(1)
java·spring boot·后端
a努力。8 分钟前
中国电网Java面试被问:RPC序列化的协议升级和向后兼容
java·开发语言·elasticsearch·面试·职场和发展·rpc·jenkins
毕设源码-钟学长11 分钟前
【开题答辩全过程】以 基于SSM框架的月子中心管理系统的设计与实现为例,包含答辩的问题和答案
java
码农水水15 分钟前
得物Java面试被问:大规模数据的分布式排序和聚合
java·开发语言·spring boot·分布式·面试·php·wpf
Chan1620 分钟前
【 微服务SpringCloud | 模块拆分 】
java·数据结构·spring boot·微服务·云原生·架构·intellij-idea
独断万古他化22 分钟前
【二分算法 深度解析】二段性思维与经典题型全通关
java·算法
摇滚侠22 分钟前
尚硅谷 Nginx 教程(亿级流量 Nginx 架构设计),基本使用,笔记 6-42
java·笔记·nginx
大鳥26 分钟前
Hive on Spark SQL 性能优化权威指南
hive·sql·spark
SenChien27 分钟前
Java大模型应用开发day06-天机ai-学习笔记
java·spring boot·笔记·学习·大模型应用开发·springai
大只鹅34 分钟前
Stream使用
java·开发语言