遇到某一個要計算的欄位,資料裡有NULL或都有值,在計算時不加以處理抓出來幾千幾百筆一個一個在網頁程式判繼是NULL要怎樣,非NULL又無樣,效率會拖得很慢。
好在SQL可以先幫我處理這個部份,需求是如果是NULL,預設為100,非NULL以抓出來的值為主。
善用 ISNULL (MS SQL/T-SQL) 或 NVL (Oracle/PLSQL) 函式,它們的語法近似:
ISNULL(A, B)
NVL(A, B)
上面兩個式子,都代表著,若是 A 不等於 NULL,則傳回 A,否則傳回 B。
實際運用:
Select sum(ROUND(a.STIPEND_AMT * (NVL(a.DISCOUNT_RATE, 100) /100))) as STIPEND_AMT From Pay_Emp a
沒有留言:
張貼留言