解决:Oracle数据库中Left join on 后面为null时匹配不上

简介: 解决:Oracle数据库中Left join on 后面为null时匹配不上

1:记录

最近在公司开发遇到一个小需求,在级联查询时, 当ON.... AND .... 时,ON后面的条件为NULL ,AND 后面的条件不为NULL。要求返回A表与B表匹配上的数据。

2:遇到问题

 当ON 后面的条件为NULL,AND 后的条件不为NULL。

例:

ON NULL = NULL AND 6 = 6

   使用级联查询时,只返回主表中的数据,次表中的数据却没有匹配上显示都是NULL(可是明明都有数据)

3:解决过程

3.1 临时表A

SQL:

SELECT 
            PROD_TYPE,
            CAST(COUNT(WORK_ORDER_ID) AS float) AS 计划数量,
            SUBSTR(START_DATE, 1, 7)            AS START_DATE,
            MAX(TO_CHAR(DATA_TIME, 'YYYY-MM'))  AS 统计日期,
            MAX(STAT_TIME)                      AS 创建时间
     FROM DWS_WORK_ORDER_INFO
     GROUP BY SUBSTR(START_DATE, 1, 7), PROD_TYPE

f914c6172da248c7aaf70be022aff99d.png

3.2  临时表B

SQL:

 SELECT CAST(COUNT(WORK_ORDER_ID) AS float) AS 完成数量,
           SUBSTR(START_DATE,1,7)      AS START_DATE,
           PROD_TYPE
    FROM BRAIN.DWS_WORK_ORDER_INFO
    WHERE IF_COMP = '是'
    GROUP BY SUBSTR(START_DATE,1,7), PROD_TYPE

0537ca910a004c6e9b364665bffbafad.png此时我想通过LEFT JOIN 左关联查出  PROD_TYPE = NULL  时的计划数量和完成数量关联条件为:

ON a.PROD_TYPE = b.PROD_TYPE
AND a.START_DATE = b.START_DATE

3.3 错误SQL(不符合需求)

select
    a.计划数量,
    a.PROD_TYPE,
    b.PROD_TYPE,
    a.START_DATE,
    b.START_DATE,
    b.完成数量
from(SELECT 
            PROD_TYPE,
            CAST(COUNT(WORK_ORDER_ID) AS float) AS 计划数量,
            SUBSTR(START_DATE, 1, 7)            AS START_DATE,
            MAX(TO_CHAR(DATA_TIME, 'YYYY-MM'))  AS 统计日期,
            MAX(STAT_TIME)                      AS 创建时间
     FROM DWS_WORK_ORDER_INFO
     GROUP BY SUBSTR(START_DATE, 1, 7), PROD_TYPE) a
         LEFT JOIN (
    --已完成
    SELECT CAST(COUNT(WORK_ORDER_ID) AS float) AS 完成数量,
           SUBSTR(START_DATE,1,7)      AS START_DATE,
           PROD_TYPE
    FROM DWS_WORK_ORDER_INFO
    WHERE IF_COMP = '是'
    GROUP BY SUBSTR(START_DATE,1,7), PROD_TYPE ) b
             ON  a.PROD_TYPE = b.PROD_TYPE
            AND a.START_DATE = b.START_DATE

执行后的结果:

很明显2023-10月的 PROD_TYPE为null 时 临时表B的数据没有匹配上,后来查询资料发现,联表查询时,null≠null

72b0e0db6dd4408d80bd14cd35ded942.png

4:解决方法

这里可以使用 NVL() ,IFNULL(), 函数均可以
COALESCE(a.PROD_TYPE,-1) = COALESCE(b.PROD_TYPE,-1)
select
    a.计划数量,
    a.PROD_TYPE,
    b.PROD_TYPE,
    a.START_DATE,
    b.START_DATE,
    b.完成数量
from(SELECT 
            PROD_TYPE,
            CAST(COUNT(WORK_ORDER_ID) AS float) AS 计划数量,
            SUBSTR(START_DATE, 1, 7)            AS START_DATE,
            MAX(TO_CHAR(DATA_TIME, 'YYYY-MM'))  AS 统计日期,
            MAX(STAT_TIME)                      AS 创建时间
     FROM DWS_WORK_ORDER_INFO
     GROUP BY SUBSTR(START_DATE, 1, 7), PROD_TYPE) a
         LEFT JOIN (
    --已完成
    SELECT CAST(COUNT(WORK_ORDER_ID) AS float) AS 完成数量,
           SUBSTR(START_DATE,1,7)      AS START_DATE,
           PROD_TYPE
    FROM DWS_WORK_ORDER_INFO
    WHERE IF_COMP = '是'
    GROUP BY SUBSTR(START_DATE,1,7), PROD_TYPE ) b
             -- 这里可以使用 NVL() ,IFNULL() 函数均可以
             ON  COALESCE(a.PROD_TYPE,-1) = COALESCE(b.PROD_TYPE,-1)
            AND a.START_DATE = b.START_DATE

执行结果:

9593ad967d7f4549869ef6a2b80271cb.png

目录
相关文章
|
2天前
|
Oracle 关系型数据库 MySQL
实时计算 Flink版操作报错合集之采集oracle的时候报ORA-65040:不允许从可插入数据库内部执行该操作如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
20 3
|
5天前
|
SQL Oracle 安全
Oracle11g更改数据库名(详细教程)
Oracle11g更改数据库名(详细教程)
15 1
|
5天前
|
DataWorks Oracle 关系型数据库
DataWorks操作报错合集之尝试从Oracle数据库同步数据到TDSQL的PG版本,并遇到了与RAW字段相关的语法错误,该怎么处理
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
35 0
|
3天前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用合集之可以通过配置Oracle数据库的schema注册表来监测表结构的变化吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
10 1
|
5天前
|
Oracle 关系型数据库 数据库
Oracle数据库协议适配器错误解决方法
Oracle数据库协议适配器错误解决方法
12 2
|
5天前
|
存储 Oracle 关系型数据库
实验三 Oracle数据库的创建和管理
实验三 Oracle数据库的创建和管理
15 1
|
5天前
|
SQL Oracle 关系型数据库
实验一 安装和使用Oracle数据库
实验一 安装和使用Oracle数据库
16 1
|
5天前
|
Oracle Java 关系型数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
17 6
|
5天前
|
SQL Oracle 关系型数据库
零基础入门 Oracle数据库:轻松上手
零基础入门 Oracle数据库:轻松上手
8 0
|
5天前
|
Oracle 关系型数据库 Java
java操作多数据源将oracle数据同步达梦数据库
java操作多数据源将oracle数据同步达梦数据库

推荐镜像

更多