」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > SQL 中的 NULL 處理

SQL 中的 NULL 處理

發佈於2024-07-31
瀏覽:176

NULL Handling in SQL

介紹

在 SQL 中處理 NULL 值是每個資料庫專業人員必須掌握的基本面向。 NULL 表示資料庫表中缺少或未定義的值,正確處理這些值對於確保資料操作的完整性和準確性至關重要。本文將深入探討 SQL 中 NULL 的概念、其意義以及處理 NULL 值的各種策略。

了解 SQL 中的 NULL

SQL中的NULL是一個特殊標記,用來指示資料庫中不存在某個資料值。它不等於空字串或零值。相反,NULL 表示不存在任何值。資料庫表中 NULL 值的存在可能會影響查詢結果,尤其是在執行比較、聚合和聯結等操作時。

NULL 的主要特徵

  1. 不確定值:NULL表示未知或不確定值。
  2. 非可比性:涉及 NULL 的比較(例如 =、)總是產生 NULL,而不是 TRUE 或 FALSE。
  3. 函數中的特殊處理:許多 SQL 函數在處理 NULL 值時都有特定的行為。

在 SQL 中使用 NULL

檢查 NULL

若要檢查值是否為 NULL,請使用 IS NULL 或 IS NOT NULL 運算子。例如:

SELECT * FROM employees WHERE manager_id IS NULL;

此查詢檢索沒有經理的所有員工。

NULL 和比較運算符

使用標準比較運算子(=、!=、

SELECT * FROM employees WHERE manager_id = NULL;

此查詢不會傳回任何行,即使某些 manager_id 值為 NULL。相反,您應該使用:

SELECT * FROM employees WHERE manager_id IS NULL;

聚合中的 NULL

SUM、AVG、COUNT 等聚合函數對 NULL 值的處理方式不同。例如,SUM 和 AVG 忽略 NULL 值,而 COUNT 可以在明確指定的情況下對它們進行計數。

SELECT SUM(salary) FROM employees;  -- NULL values are ignored
SELECT AVG(salary) FROM employees;  -- NULL values are ignored
SELECT COUNT(manager_id) FROM employees;  -- NULL values are ignored
SELECT COUNT(*) FROM employees WHERE manager_id IS NULL;  -- Counts only NULL values

處理連線中的 NULL

執行連線時,NULL 值可能會導致意外結果。例如,INNER JOIN 排除連接條件中具有 NULL 值的行,而 LEFT JOIN 則包括它們。

SELECT e.name, d.department_name
FROM employees e
LEFT JOIN departments d ON e.department_id = d.id;

由於 LEFT JOIN,此查詢會擷取所有員工,包括那些沒有部門的員工。

處理 SQL 查詢中的 NULL

使用合併

COALESCE 函數傳回表達式清單中的第一個非 NULL 值。它對於用預設值替換 NULL 很有用。

SELECT name, COALESCE(manager_id, 'No Manager') AS manager_id
FROM employees;

此查詢將 NULL manager_id 值替換為字串「No Manager」。

使用 IFNULL 或 ISNULL

許多 SQL 方言提供 IFNULL (MySQL) 或 ISNULL (SQL Server) 等函數來處理 NULL 值。

-- MySQL
SELECT name, IFNULL(manager_id, 'No Manager') AS manager_id FROM employees;

-- SQL Server
SELECT name, ISNULL(manager_id, 'No Manager') AS manager_id FROM employees;

使用 NULLIF

如果兩個參數相等,NULLIF 函數傳回 NULL;否則,它會傳回第一個參數。它對於避免被零除錯誤很有用。

SELECT price / NULLIF(quantity, 0) AS unit_price
FROM products;

此查詢透過在數量為零時傳回 NULL 來防止被零除。

NULL 處理的最佳實踐

  1. 定義預設值:建立表格時,定義列的預設值以盡量減少 NULL 的出現。
  2. 使用適當的函數:利用 COALESCE、IFNULL 和 NULLIF 等函數有效地處理 NULL 值。
  3. 驗證資料:實施資料驗證規則以防止出現不必要的 NULL 值。
  4. 考慮資料庫設計:設計資料庫架構以適當處理 NULL 值,考慮對查詢和效能的影響。

結論

在 SQL 中處理 NULL 值需要仔細考慮和理解它們在不同操作中的行為。透過使用適當的 SQL 函數並遵循最佳實踐,您可以確保資料庫查詢產生準確且可靠的結果。無論您是檢查 NULL、執行聚合還是連接表,正確的 NULL 處理對於維護資料完整性和在 SQL 操作中實現所需結果都至關重要。

版本聲明 本文轉載於:https://dev.to/kellyblaire/null-handling-in-sql-1mp2?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何擴展 JavaScript 中的內建錯誤物件?
    如何擴展 JavaScript 中的內建錯誤物件?
    擴充 JavaScript 中的 Error要擴充 JavaScript 中的內建 Error 對象,您可以使用 extends 關鍵字定義 Error 的子類別。這允許您使用附加屬性或方法建立自訂錯誤。 在 ES6 中,您可以定義自訂錯誤類,如下所示:class MyError extends E...
    程式設計 發佈於2024-11-03
  • 將測試集中在網域上。 PHPUnit 範例
    將測試集中在網域上。 PHPUnit 範例
    介紹 很多時候,開發人員嘗試測試 100%(或幾乎 100%)的程式碼。顯然,這是每個團隊應該為他們的專案達到的目標,但從我的角度來看,只應該完全測試整個程式碼的一部分:您的網域。 域基本上是程式碼中定義項目實際功能的部分。例如,當您將實體持久保存到資料庫時,您的網域不負責將其持...
    程式設計 發佈於2024-11-03
  • 如何使用 SQL 搜尋列中的多個值?
    如何使用 SQL 搜尋列中的多個值?
    使用 SQL 在列中搜尋多個值建立搜尋機制時,通常需要在同一列中搜尋多個值場地。例如,假設您有一個搜尋字串,例如“Sony TV with FullHD support”,並且想要使用該字串查詢資料庫,將其分解為單字。 透過利用 IN 或 LIKE 運算符,您可以實現此功能。 使用 IN 運算子IN...
    程式設計 發佈於2024-11-03
  • 如何安全地從 Windows 登錄讀取值:逐步指南
    如何安全地從 Windows 登錄讀取值:逐步指南
    如何安全地從Windows 註冊表讀取值檢測登錄項目是否存在確定登錄項目是否存在: LONG lRes = RegOpenKeyExW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Perl", 0, KEY_READ, &hKey); if (lRes...
    程式設計 發佈於2024-11-03
  • Staat原始碼中的useBoundStoreWithEqualityFn有解釋。
    Staat原始碼中的useBoundStoreWithEqualityFn有解釋。
    在這篇文章中,我們將了解Zustand原始碼中useBoundStoreWithEqualityFn函數是如何使用的。 上述程式碼摘自https://github.com/pmndrs/zustand/blob/main/src/traditional.ts#L80 useBoundStoreWi...
    程式設計 發佈於2024-11-03
  • 如何使用 Go 安全地連接 SQL 查詢中的字串?
    如何使用 Go 安全地連接 SQL 查詢中的字串?
    在Go 中的SQL 查詢中連接字串雖然文字SQL 查詢提供了一種簡單的資料庫查詢方法,但了解將字串文字與值連接的正確方法至關重要以避免語法錯誤和類型不匹配。 提供的查詢語法:query := `SELECT column_name FROM table_name WHERE colu...
    程式設計 發佈於2024-11-03
  • 如何在 Python 中以程式設計方式從 Windows 剪貼簿檢索文字?
    如何在 Python 中以程式設計方式從 Windows 剪貼簿檢索文字?
    以程式設計方式存取Windows 剪貼簿以在Python 中進行文字擷取Windows 剪貼簿充當資料的臨時存儲,從而實現跨應用程式的無縫數據共享。本文探討如何使用 Python 從 Windows 剪貼簿檢索文字資料。 使用 win32clipboard 模組要從 Python 存取剪貼簿,我們可...
    程式設計 發佈於2024-11-03
  • 使用 MySQL 預存程序時如何存取 PHP 中的 OUT 參數?
    使用 MySQL 預存程序時如何存取 PHP 中的 OUT 參數?
    使用MySQL 預存程序存取PHP 中的OUT 參數使用MySQL 儲存程序存取PHP 中的OUT 參數使用PHP 在MySQL 中處理預存程序時,取得由於文件有限,「 OUT”參數可能是一個挑戰。然而,這個過程可以透過利用 mysqli PHP API 來實現。 使用mysqli$mysqli =...
    程式設計 發佈於2024-11-03
  • 在 Kotlin 中處理 null + null:會發生什麼事?
    在 Kotlin 中處理 null + null:會發生什麼事?
    在 Kotlin 中處理 null null:會發生什麼事? 在 Kotlin 中進行開發時,您一定會遇到涉及 null 值的場景。 Kotlin 的 null 安全方法眾所周知,但是當您嘗試新增 null null 時會發生什麼?讓我們來探討一下這個看似簡單卻發人深省的情況吧! ...
    程式設計 發佈於2024-11-03
  • Python 字串文字中「r」前綴的意思是什麼?
    Python 字串文字中「r」前綴的意思是什麼?
    揭示「r」前綴在字串文字中的作用在Python中創建字串文字時,你可能遇到過神秘的“r” ” 前綴。此前綴具有特定的含義,可能會影響字串的解釋,尤其是在處理正則表達式時。“r”前綴表示該字串應被視為「原始」字串。 &&&]在常規字串中,轉義序列如\ n 和\t 被解釋為表示特殊字符,例如換行符和製表...
    程式設計 發佈於2024-11-03
  • 如何解決舊版 Google Chrome 的 Selenium Python 中的「無法找到 Chrome 二進位」錯誤?
    如何解決舊版 Google Chrome 的 Selenium Python 中的「無法找到 Chrome 二進位」錯誤?
    在舊版Google Chrome 中無法使用Selenium Python 查找Chrome 二進位錯誤在舊版Google Chrome 中使用Python 中的Selenium 時,您可能會遇到以下錯誤:WebDriverException: unknown error: cannot find ...
    程式設計 發佈於2024-11-03
  • `.git-blame-ignore-revs` 忽略批量格式變更。
    `.git-blame-ignore-revs` 忽略批量格式變更。
    .git-blame-ignore-revs 是 2.23 版本中引入的一项 Git 功能,允许您忽略 git Blame 结果中的特定提交。这对于在不改变代码实际功能的情况下更改大量行的批量提交特别有用,例如格式更改、重命名或在代码库中应用编码标准。通过忽略这些非功能性更改,gitblame 可以...
    程式設計 發佈於2024-11-03
  • 掌握函數參數:JavaScript 中的少即是多
    掌握函數參數:JavaScript 中的少即是多
    嘿,開發者們! ?今天,讓我們深入探討編寫乾淨、可維護的 JavaScript 的關鍵方面:管理函數參數 太多參數的問題 你有遇過這樣的函數嗎? function createMenu(title, body, buttonText, cancellable, theme, fon...
    程式設計 發佈於2024-11-03
  • 如何使用 FastAPI WebSockets 維護 Jinja2 範本中的即時評論清單?
    如何使用 FastAPI WebSockets 維護 Jinja2 範本中的即時評論清單?
    使用FastAPI WebSockets 更新Jinja2 範本中的項目清單在評論系統中,維護最新的評論清單至關重要提供無縫維護的使用者體驗。當新增評論時,它應該反映在模板中,而不需要手動重新加載。 在Jinja2中,更新評論清單通常是透過API呼叫來實現的。然而,這種方法可能會引入延遲並損害使用者...
    程式設計 發佈於2024-11-03
  • 掌握 SQL 查詢:&#教師薪資格查詢&# 項目
    掌握 SQL 查詢:&#教師薪資格查詢&# 項目
    您是否希望提升 SQL 技能並學習如何有效管理 MySQL 資料庫? LabEx 提供的教師薪資格式查詢專案就是您的最佳選擇。這個綜合計畫將引導您完成在大學資料庫中查詢和格式化教職員工薪資的過程,為您提供必要的知識和技能,以在資料管理工作中脫穎而出。 介紹 在這個引人入勝的專案中,...
    程式設計 發佈於2024-11-03

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3