欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解讀SQL中GROUP BY和HAVING子句中使用NULL條件問(wèn)題

 更新時(shí)間:2024年10月16日 16:23:05   作者:qianer0_0  
在使用SQL進(jìn)行數(shù)據(jù)查詢時(shí),可能會(huì)遇到查詢結(jié)果為空的情況,這通常與GROUP BY和HAVING子句的使用有關(guān),尤其是在處理包含NULL值的字段時(shí),當(dāng)使用GROUP BY進(jìn)行數(shù)據(jù)分組,并在HAVING子句中直接判斷字段是否為NULL時(shí)

SQL中GROUP BY和HAVING子句中使用NULL條件

  • SQL :
SELECT COUNT(1), tid, sap_do, batch, skucode,batch 
FROM lt 
WHERE IFNULL(sap_do, '') != '' 
AND created_time >= 1722441600 
GROUP BY tid, sap_do, skucode 
HAVING COUNT(1) > 1 
AND batch IS NULL; 

查詢結(jié)果為空;實(shí)際數(shù)據(jù)庫(kù)存在batch IS NULL的

  • 修改后:
SELECT COUNT(1), tid, sap_do, skucode, batch 
FROM lt 
WHERE IFNULL(sap_do, '') != '' 
AND created_time >= 1722441600 
GROUP BY tid, sap_do, skucode 
HAVING COUNT(1) > 1 
AND SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) > 0;

問(wèn)題的核心在于 GROUP BY 和 HAVING 子句的工作方式,以及 NULL 的處理規(guī)則

1. HAVING batch IS NULL 沒(méi)有數(shù)據(jù)的原因

當(dāng)你使用 GROUP BY 并在 HAVING 子句中直接使用 batch IS NULL,SQL 會(huì)在分組后的結(jié)果中查找 batch 的值是否為 NULL。但是由于 GROUP BY 會(huì)對(duì)所有同一組內(nèi)的數(shù)據(jù)進(jìn)行聚合,batch 字段可能包含 NULL 和非 NULL 的混合值。

對(duì)于 GROUP BY 而言,它不會(huì)簡(jiǎn)單地保留 batch 字段的某一個(gè)特定值,因此如果某個(gè)分組內(nèi)的 batch 值既有 NULL 又有非 NULL 的情況,batch IS NULL 這個(gè)條件會(huì)失效,因?yàn)?SQL 無(wú)法確定這一組的 batch 值究竟是 NULL 還是非 NULL。

直接使用 HAVING batch IS NULL 通常只能在整個(gè)分組的 batch 全部是 NULL 的情況下才會(huì)生效。

簡(jiǎn)而言之,當(dāng) batch 列在分組后不全是 NULL 時(shí),HAVING batch IS NULL 無(wú)法篩選出結(jié)果。

2. HAVING SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) > 0 結(jié)果正確的原因

SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) 的邏輯是通過(guò) CASE 語(yǔ)句來(lái)計(jì)算某個(gè)分組內(nèi) batch 列為 NULL 的記錄數(shù)。

SUM 是對(duì)整個(gè)分組內(nèi)的每一條記錄進(jìn)行處理,因此即使該組內(nèi)存在 batch 的非 NULL 值,只要有任何一條記錄的 batch 是 NULL,SUM 就能正確計(jì)算出這一組包含 NULL 值的數(shù)量。

解釋:

  • SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) > 0:通過(guò)這個(gè) SUM,我們計(jì)算出當(dāng)前分組內(nèi)有多少條記錄的 batch 為 NULL,如果結(jié)果大于 0,說(shuō)明這一組內(nèi)存在 NULL 值的 batch。
  • HAVING batch IS NULL:只能篩選出分組后 batch 的值完全為 NULL 的情況,無(wú)法處理那些包含 NULL 和非 NULL 值的分組。

總結(jié)

HAVING batch IS NULL 只能處理整個(gè)分組中的 batch 全為 NULL 的情況,這在有混合值的分組中會(huì)導(dǎo)致結(jié)果為空。

HAVING SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) > 0 可以處理分組中包含 NULL 和非 NULL 的情況,因此它能正確返回包含 NULL 值的分組。

這種 SUM(CASE WHEN…) 邏輯提供了更細(xì)粒度的控制,可以確保即使在分組中存在多個(gè)不同的 batch 值,依然可以正確識(shí)別出那些包含 NULL 的分組。

補(bǔ)充

如果查詢id字段的話 上面的SQL結(jié)果會(huì)發(fā)現(xiàn),id結(jié)果不是我們想要的batch為null的行ID

可改造SQL為下面 執(zhí)行:

SELECT id, tid, sap_do, skucode, batch 
FROM lt
WHERE batch IS NULL
AND (tid, sap_do, skucode) IN (
    SELECT tid, sap_do, skucode
    FROM lt 
    WHERE IFNULL(sap_do, '') != ''
    AND created_time >= 1725120000
    GROUP BY tid, sap_do, skucode
    HAVING COUNT(1) > 1
    AND SUM(CASE WHEN batch IS NULL THEN 1 ELSE 0 END) > 0
);

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論