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写死就好了,字段该是啥类型,该写啥默认值,一开始就能确定了。

相关推荐
AI进化营-智能译站13 小时前
ROS2 C++开发系列06:变量、数据类型与IO实战
java·开发语言·c++·ai
薪火铺子14 小时前
OAuth2 + JWT 微服务认证方案深度解析
java·运维·微服务
diangedan15 小时前
Android冻屏
android·java
东风破13721 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
abcnull21 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡21 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手21 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
juniperhan1 天前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
ID_180079054731 天前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路1 天前
C++23概述
java·c++·c++23