在SQL中,COALESCE
函數(shù)是一個非常有用的函數(shù),用于從其參數(shù)列表中返回第一個非NULL
值。如果所有給定的參數(shù)都是NULL
,那么COALESCE
函數(shù)將返回NULL
。這個函數(shù)可以接受多個參數(shù),使其在處理可能出現(xiàn)的NULL
值時非常靈活和強大。
語法
COALESCE(expression1, expression2, ..., expressionN)
-
expression1, expression2, ..., expressionN
:是COALESCE
函數(shù)要檢查的表達(dá)式列表。函數(shù)會從左到右評估這些表達(dá)式,返回第一個非NULL
的表達(dá)式值。
使用場景
-
默認(rèn)值設(shè)置:當(dāng)你希望某個列或表達(dá)式返回一個默認(rèn)值(而不是
NULL
)時,COALESCE
可以提供這個默認(rèn)值。這對于數(shù)據(jù)報告和用戶界面顯示特別有用,因為你可以避免顯示NULL
值,而是顯示一個更有意義的默認(rèn)值。 -
數(shù)據(jù)清洗:在處理含有
NULL
值的數(shù)據(jù)時,COALESCE
可以幫助你將這些NULL
值轉(zhuǎn)換為實際的數(shù)值或文本,便于分析和計算。 -
條件選擇:
COALESCE
可以用于基于數(shù)據(jù)存在性(是否為NULL
)條件性地選擇值。
示例
假設(shè)你有一個Employees
表,其中包含員工的salary
列,你想要選擇一個列,顯示員工的薪水,如果薪水是NULL
,則顯示0
。
SELECT COALESCE(salary, 0) AS effective_salary FROM Employees;
這個查詢通過COALESCE
函數(shù)確保了effective_salary
列不會包含NULL
值;如果salary
是NULL
,則effective_salary
會顯示為0
。
小結(jié)
COALESCE
函數(shù)提供了一種簡單有效的方式來處理SQL查詢中的NULL
值,使得數(shù)據(jù)分析和展示更加靈活和清晰。它是處理NULL
值時應(yīng)該考慮的首選函數(shù)之一,特別是當(dāng)你需要從一組可能的NULL
值中選擇第一個實際存在的值時。
leetcode例題:1378. 使用唯一標(biāo)識碼替換員工ID
題目描述
Employees
表:
+---------------+---------+
| Column Name | Type |
+---------------+---------+
| id | int |
| name | varchar |
+---------------+---------+
在 SQL 中,id 是這張表的主鍵。
這張表的每一行分別代表了某公司其中一位員工的名字和 ID 。
EmployeeUNI
表:
+---------------+---------+
| Column Name | Type |
+---------------+---------+
| id | int |
| unique_id | int |
+---------------+---------+
在 SQL 中,(id, unique_id) 是這張表的主鍵。
這張表的每一行包含了該公司某位員工的 ID 和他的唯一標(biāo)識碼(unique ID)。
展示每位用戶的 唯一標(biāo)識碼(unique ID );如果某位員工沒有唯一標(biāo)識碼,使用 null 填充即可。
你可以以 任意 順序返回結(jié)果表。
返回結(jié)果的格式如下例所示。
示例 1:
輸入:
Employees 表:
+----+----------+
| id | name |
+----+----------+
| 1 | Alice |
| 7 | Bob |
| 11 | Meir |
| 90 | Winston |
| 3 | Jonathan |
+----+----------+
EmployeeUNI 表:
+----+-----------+
| id | unique_id |
+----+-----------+
| 3 | 1 |
| 11 | 2 |
| 90 | 3 |
+----+-----------+
輸出:
+-----------+----------+
| unique_id | name |
+-----------+----------+
| null | Alice |
| null | Bob |
| 2 | Meir |
| 3 | Winston |
| 1 | Jonathan |
+-----------+----------+
解釋:
Alice and Bob 沒有唯一標(biāo)識碼, 因此我們使用 null 替代。
Meir 的唯一標(biāo)識碼是 2 。
Winston 的唯一標(biāo)識碼是 3 。
Jonathan 唯一標(biāo)識碼是 1 。
解答
要解決這個問題,你可以使用 SQL 的 LEFT JOIN
語句來連接 Employees
表和 EmployeeUNI
表,并且使用 COALESCE
函數(shù)來處理那些沒有匹配 unique_id
的情況,將它們填充為 NULL
。LEFT JOIN
會返回左表 (Employees
) 的所有行,如果左表的行在右表 (EmployeeUNI
) 中沒有匹配行,則結(jié)果中對應(yīng)行的 EmployeeUNI
表列會包含 NULL
值。
以下是實現(xiàn)該邏輯的 SQL 查詢:
SELECT
COALESCE(EU.unique_id, NULL) AS unique_id,
E.name
FROM
Employees E
LEFT JOIN
EmployeeUNI EU ON E.id = EU.id
ORDER BY
E.id; -- 或者根據(jù)需要排序,比如按照 name 或 unique_id
這個查詢做了以下事情:文章來源:http://www.zghlxwxcb.cn/news/detail-859767.html
-
FROM Employees E
- 從Employees
表開始,為表設(shè)置了一個別名E
以簡化后續(xù)引用。 -
LEFT JOIN EmployeeUNI EU ON E.id = EU.id
- 通過LEFT JOIN
將Employees
表和EmployeeUNI
表連接起來,基于兩表的id
字段。EmployeeUNI
表也被賦予了別名EU
。 -
COALESCE(EU.unique_id, NULL) AS unique_id
-COALESCE
函數(shù)返回其參數(shù)列表中的第一個非NULL
值。在這里,如果EU.unique_id
是NULL
(意味著LEFT JOIN
沒有找到匹配的行),則結(jié)果仍然是NULL
。雖然在這種情況下使用COALESCE
函數(shù)可能看起來多余(因為EU.unique_id
本身在沒有匹配的情況下就是NULL
),但它在這里說明了如何處理可能的NULL
值。實際上,你可以直接選擇EU.unique_id
。 -
ORDER BY E.id
- 結(jié)果按照員工的id
排序。這一步是可選的,取決于你想如何展示結(jié)果。
注意,這個查詢確保了即使某些員工沒有對應(yīng)的 unique_id
,他們的名字仍然會出現(xiàn)在查詢結(jié)果中,unique_id
列用 NULL
表示他們?nèi)鄙傥ㄒ粯?biāo)識碼。文章來源地址http://www.zghlxwxcb.cn/news/detail-859767.html
到了這里,關(guān)于sql中COALESCE函數(shù)詳解的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!