Oracle函數——COALESCE

COALESCE

含義:COALESCE是一個函數, (expression_1, expression_2, …,expression_n)依次參考各參數表達式,遇到非null值即停止並返回該值。如果所有的表達式都是空值,最終將返回一個空值。使用COALESCE在於大部分包含空值的表達式最終將返回空值。
用法:COALESCE(expression_1, expression_2, ...,expression_n)
例子

SELECT COALESCE(NULL,NULL,3,4,5) FROM dual  

其返回結果爲:3

SELECT A.ID,SUM(COALESCE(A.SHUL,0)+COALESCE(A.PZSHUL,0)) from t_order as A group by A.ID

這樣就不會因爲數據庫中的值爲NULL而計算錯誤
返回值:返回第一個非NULL表達式的類型
擴展

COALESCE(expression1,...n) 與此 CASE 函數等價:

CASE
WHEN (expression1 IS NOT NULL) THEN expression1
...
WHEN (expressionN IS NOT NULL) THEN expressionN
ELSE NULL

注意
空值加任何值都是空值,空值 乘任何值也都是空值,依此類推。
所有表達式必須是相同類型,或者可以隱性轉換爲相同的類型。

轉自 https://www.cnblogs.com/zuiyue_jing/p/10135815.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章