為什麼「CODE!='C'」在 MySQL 查詢中排除 NULL 值?
Jan 09, 2025 pm 07:37 PMMySQL 中 NULL 值的比較
在 MySQL 中,比較包含 NULL 值的欄位可能會帶來挑戰,因為其行為與標準的等值比較不同。本文探討了為什麼像 "SELECT * from TABLE where CODE!='C'" 這樣的查詢會排除 CODE=NULL 的行,即使 'C' 不是 NULL。
NULL 比較的行為
當將列與非 NULL 值(例如 "CODE!='C'")進行比較時,查詢會傳回 CODE 符合 'C' 的行,並排除所有其他值,包括 NULL。這種行為源自於 SQL 將 NULL 視為一個不參與標準比較的獨特值。
要將 NULL 值包含在比較中,必須使用 IS NULL 或 IS NOT NULL 運算子明確檢查它們。例如,以下查詢將傳回 CODE 為 NULL 或不等於 'C' 的所有行:
SELECT * from TABLE where CODE IS NULL OR CODE!='C'
登入後複製
CODE!='C' 行為的解釋
"CODE!='C'" 不傳回 CODE=NULL 的行的原因是,該查詢對於任何涉及 NULL 的比較都將評估為 false。即使 'C' 不是 NULL,將其與 NULL 值進行比較始終會導致 false。
替代比較運算子
MySQL 提供了一種替代比較運算子 "
透過使用 "CODE
以上是為什麼「CODE!='C'」在 MySQL 查詢中排除 NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器)
