oracle中使用sql查询时字段为空则赋值默认
前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。
?oracle 通過 nvl( )函數sql 查詢時為 空值 賦默認值
oracle 函數介紹之nvl
?
函數聲明:nvl(col,val)
說明:當col為空時取val作為返回值,當col不為空時取col值。
用處:最主要的是格式化數據,比如計算金額時,不想出現空數據,可以使用nvl(JINE,0)來得到0。由于null+(或-,*,/)數字等于null,所以在表達式中對可能為空的值要使用nvl由于null!=null,有時對可能為空的列進行條件查詢時,可能出現結果集丟失數據問題,加上nvl就不會了。
?
經典用法:
通過查詢獲得某個字段的合計值,如果這個值為null將給出一個預設的默認值 例如: select nvl(sum(t.字段),1) ?from table t 就表示如果sum(t.字段) = NULL 就返回 1 另一個有關的有用方法 declare i integer select nvl(sum(t.字段),1) into i from table t?這樣就可以把獲得的合計值存儲到變量i中,如果查詢的值為null就把它的值設置為默認的1 orcale中: select nvl(rulescore,0) from zwjc_graderule where rulecode='FWTD';?如果記錄中不存在rulecode ='FWTD'的數據.則查不出數據. select nvl(rulescore,0) into rule_score from zwjc_graderule where rulecode='FWTD';會報查不到數據的錯 select nvl(sum(rulescore),0) from zwjc_graderule where rulecode='FWTD';?如果記錄中不存在rulecode ='FWTD'的數據.還是可以得到一行列名為nvl(rulescore,0),值為0的數據. select nvl(sum(rulescore),0) into rule_score from zwjc_graderule where rulecode='FWTD'; 不會報錯?
?
?
oracle 函數介紹之nvl2
Oracle在NVL函數的功能上擴展,提供了NVL2函數。 NVL2(E1, E2, E3)的功能為:如果E1為NULL,則函數返回E3,否則返回E2。E2和E3類型不同的話,E3會轉換為E2的類型。?
?
?限制: 1)?E1可以是任意類型,E2,E3不能是long類型。
?????? 2) 如果 E2是字符類型,那么E3轉為字符型再比較(null除外)。
?????? 3) 如果 E2是數值類型,那么E3也轉為對應的數值類型。
?????? 4) 各個參數都不能是邏輯表達式.
oracle 函數介紹之nullif
格式: nullif(expr1,expr2)? 等價于 "case when expr1 = expr 2 then null else expr1 end",相等返回NULL,不等返回expr1.限制: expr1不能是標識符null,錄入nullif(null,expr2)那么會提示錯誤。
?????????? expr1,expr2 都必須是一個變量或者是一個常量表達式,不能是邏輯表達式。
?
?
?
?
oracle 函數介紹之lnnvl(a)?
?
?
?
a是一個表達式
lnnvl只能用于where子句中;表達式的操作符號不能包含 AND, OR,? BETWEEN。
如果a的結果是false或者是unknown,那么lnnvl返回true;如果a的結果是true,返回false.
"如果a的結果是false或者是unknown,那么lnnvl返回true",這個很重要,因為一個空值或者unknown的值和另外一個常量或者有值的變量比較的時候,返回的總是unknown,所以
lnnvl(a>10)? 等價于? nvl(a,0)<=10??? 等價于? a<=10 or a is null? (假設a number(10))
說白了,lnnvl是一種特定的用于簡化表達式的函數,orcle解析的時候,應該會解析為 "a<=10 or a is null".??
?
?
oracle 函數介紹之decode()
decode()函數簡介:
主要作用:將查詢結果翻譯成其他值(即以其他形式表現出來,以下舉例說明);
使用方法:
Select decode(columnname,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)
From talbename
Where …
其中columnname為要選擇的table中所定義的column,
·含義解釋:
decode(條件,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)的理解如下:
if (條件==值1)
?then
return(翻譯值1)
elsif (條件==值2)
then
return(翻譯值2)
......
elsif (條件==值n)
?then
return(翻譯值n)
else
return(缺省值)
end if
注:其中缺省值可以是你要選擇的column name 本身,也可以是你想定義的其他值,比如Other等;
舉例說明:
現定義一table名為output,其中定義兩個column分別為monthid(var型)和sale(number型),若sale值=1000時翻譯為D,=2000時翻譯為C,=3000時翻譯為B,=4000時翻譯為A,如是其他值則翻譯為Other;
SQL如下:
Select monthid , decode (sale,1000,'D',2000,'C',3000,'B',4000,'A',’Other’) sale from output
特殊情況:
若只與一個值進行比較
Select monthid ,decode(sale, NULL,‘---’,sale) sale from output
另:decode中可使用其他函數,如nvl函數或sign()函數等;
NVL(EXPR1,EXPR2)
若EXPR1是NULL,則返回EXPR2,否則返回EXPR1.
SELECT NAME,NVL(TO_CHAR(COMM),'NOT APPLICATION') FROM TABLE1;
如果用到decode函數中就是
select monthid,decode(nvl(sale,6000),6000,'NG','OK') from output
?
sign()函數根據某個值是0、正數還是負數,分別返回0、1、-1,
如果取較小值就是
select monthid,decode(sign(sale-6000),-1,sale,6000) from output,即達到取較小值的目的。
?
總結
以上是生活随笔為你收集整理的oracle中使用sql查询时字段为空则赋值默认的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Docker,容器,虚拟机和红烧肉
- 下一篇: 如何查看jar包的版本号?