MySQL 如何處理 IN 運算式中的 NULL 值?

Barbara Streisand
發布: 2024-10-23 18:17:05
原創
305 人瀏覽過

How Does MySQL Handle NULL Values in IN Expressions?

MySQL IN 關鍵字和NULL 值

MySQL 中的IN 關鍵字執行給定表達式和值清單之間的比較,返回布林結果(TRUE/FALSE)。但是,在某些情況下,MySQL 以不同的方式處理 NULL 值。

考慮以下查詢:

select count(*) from Table1 where CurrentDateTime>'2012-05-28 15:34:02.403504' and Error not in ('Timeout','Connection Error');
登入後複製

此查詢旨在從Table1 檢索CurrentDateTime 值大於的行「2012-05-28 15:34:02.403504」和一個不等於「逾時”或“連接錯誤”的錯誤值。令人驚訝的是,此查詢排除了帶有 NULL 值的錯誤行。

為什麼 MySQL 會忽略 IN 運算式中的 NULL 值?

MySQL 將 NULL 視為未知或未定義的值。當在 IN 表達式中使用時,MySQL 將 NULL 計算為既不是 TRUE 也不是 FALSE,從而導致未知結果。因此,IN 表達式本身的計算結果為 NULL。

修正查詢

要擷取具有NULL 錯誤值的行,有多種方法:

  1. 使用COALESCE 將NULL 值為預設值:
select count(*) from Table1 where CurrentDateTime>'2012-05-28 15:34:02.403504' and COALESCE(Error,'') not in ('Timeout','Connection Error');
登入後複製
  1. 使用IS NULL 和OR 明確檢查NULL 值:
select count(*) from Table1 where CurrentDateTime>'2012-05-28 15:34:02.403504' and (Error IS NULL OR Error not in ('Timeout','Connection Error'));
登入後複製
  1. 使用CASE 根據錯誤值分配布林結果:
select count(*) from Table1 where CurrentDateTime>'2012-05-28 15:34:02.403504' and CASE WHEN Error IS NULL THEN 1 ELSE Error not in ('Timeout','Connection Error') THEN 1 ELSE 0 END = 1;
登入後複製

這些修改確保具有NULL 錯誤值的行包含在查詢結果中。

以上是MySQL 如何處理 IN 運算式中的 NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!