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

SQL 中的 NULL 處理

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

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]刪除
最新教學 更多>
  • Java字符串非空且非null的有效檢查方法
    Java字符串非空且非null的有效檢查方法
    檢查字符串是否不是null而不是空的 if(str!= null && str.isementy())二手: if(str!= null && str.length()== 0) option 3:trim()。 isement(Isement() trim whitespace whites...
    程式設計 發佈於2025-05-18
  • Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    在ASP.NET async void void async void void void void void的設計無需返回asynchroncon而無需返回任務對象。他們在執行過程中增加未償還操作的計數,並在完成後減少。在某些情況下,這種行為可能是有益的,例如未期望或明確預期操作結果的火災和...
    程式設計 發佈於2025-05-18
  • 如何在GO編譯器中自定義編譯優化?
    如何在GO編譯器中自定義編譯優化?
    在GO編譯器中自定義編譯優化 GO中的默認編譯過程遵循特定的優化策略。 However, users may need to adjust these optimizations for specific requirements.Optimization Control in Go Compi...
    程式設計 發佈於2025-05-18
  • 反射動態實現Go接口用於RPC方法探索
    反射動態實現Go接口用於RPC方法探索
    在GO 使用反射來實現定義RPC式方法的界面。例如,考慮一個接口,例如:鍵入myService接口{ 登錄(用戶名,密碼字符串)(sessionId int,錯誤錯誤) helloworld(sessionid int)(hi String,錯誤錯誤) } 替代方案而不是依靠反射...
    程式設計 發佈於2025-05-18
  • 在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8 MySQL表中正確將Latin1字符轉換為UTF8的方法
    在UTF8表中將latin1字符轉換為utf8 ,您遇到了一個問題,其中含義的字符(例如,“jáuòiñe”)在utf8 table tabled tablesset中被extect(例如,“致電。The recommended approach to correct the data is t...
    程式設計 發佈於2025-05-18
  • 如何避免Go語言切片時的內存洩漏?
    如何避免Go語言切片時的內存洩漏?
    ,a [j:] ...雖然通常有效,但如果使用指針,可能會導致內存洩漏。這是因為原始的備份陣列保持完整,這意味著新切片外部指針引用的任何對象仍然可能佔據內存。 copy(a [i:] 對於k,n:= len(a)-j i,len(a); k
    程式設計 發佈於2025-05-18
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用時間數據時...
    程式設計 發佈於2025-05-18
  • 如何在其容器中為DIV創建平滑的左右CSS動畫?
    如何在其容器中為DIV創建平滑的左右CSS動畫?
    通用CSS動畫,用於左右運動 ,我們將探索創建一個通用的CSS動畫,以向左和右移動DIV,從而到達其容器的邊緣。該動畫可以應用於具有絕對定位的任何div,無論其未知長度如何。 問題:使用左直接導致瞬時消失 更加流暢的解決方案:混合轉換和左 [並實現平穩的,線性的運動,我們介紹了線性的轉換。...
    程式設計 發佈於2025-05-18
  • Python不會對超範圍子串切片報錯的原因
    Python不會對超範圍子串切片報錯的原因
    在python中用索引切片範圍:二重性和空序列索引單個元素不同,該元素會引起錯誤,切片在序列的邊界之外沒有。 這種行為源於索引和切片之間的基本差異。索引一個序列,例如“示例” [3],返回一個項目。但是,切片序列(例如“示例” [3:4])返回項目的子序列。 索引不存在的元素時,例如“示例” [9...
    程式設計 發佈於2025-05-18
  • Go web應用何時關閉數據庫連接?
    Go web應用何時關閉數據庫連接?
    在GO Web Applications中管理數據庫連接很少,考慮以下簡化的web應用程序代碼:出現的問題:何時應在DB連接上調用Close()方法? ,該特定方案將自動關閉程序時,該程序將在EXITS EXITS EXITS出現時自動關閉。但是,其他考慮因素可能保證手動處理。 選項1:隱式關閉終...
    程式設計 發佈於2025-05-18
  • Python元類工作原理及類創建與定制
    Python元類工作原理及類創建與定制
    python中的metaclasses是什麼? Metaclasses負責在Python中創建類對象。就像類創建實例一樣,元類也創建類。他們提供了對類創建過程的控制層,允許自定義類行為和屬性。 在Python中理解類作為對象的概念,類是描述用於創建新實例或對象的藍圖的對象。這意味著類本身是使用...
    程式設計 發佈於2025-05-17
  • 如何使用“ JSON”軟件包解析JSON陣列?
    如何使用“ JSON”軟件包解析JSON陣列?
    parsing JSON與JSON軟件包 QUALDALS:考慮以下go代碼:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    程式設計 發佈於2025-05-17
  • 人臉檢測失敗原因及解決方案:Error -215
    人臉檢測失敗原因及解決方案:Error -215
    錯誤處理:解決“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解決此問題,必須確保提供給HAAR CASCADE XML文件的路徑有效。在提供的代碼片段中,級聯分類器裝有硬編碼路徑,這可能對您的系統不准確。相反,OPENCV提...
    程式設計 發佈於2025-05-17
  • 為什麼不使用CSS`content'屬性顯示圖像?
    為什麼不使用CSS`content'屬性顯示圖像?
    在Firefox extemers屬性為某些圖像很大,&& && && &&華倍華倍[華氏華倍華氏度]很少見,卻是某些瀏覽屬性很少,尤其是特定於Firefox的某些瀏覽器未能在使用內容屬性引用時未能顯示圖像的情況。這可以在提供的CSS類中看到:。 googlepic { 內容:url(&...
    程式設計 發佈於2025-05-17
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-05-17

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

Copyright© 2022 湘ICP备2022001581号-3