今天在修改乙個儲存過程,但是遇到了游標裡的資料在迴圈時,被迴圈的表裡沒有游標裡對應的資料,然後報錯,就想給沒有的賦值0,然後使用了decode()結果還是不可以,後來試了好多,比如select count(*) from table進行判斷都不可以。最後算然用了一下判斷,將count的值進行判斷,最後才搞出來,但是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.
如果用到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語句的幾個基本函式
今天學習了 sql語句中幾個基本的函式,1 sysdate 查詢當前資料庫系統時間 select sysdate from dual 其中dual是oracle自帶的一張虛擬表,沒有任何意義,為了保證sql語句的完整性。trunc 列 值 表示式,小數的有效位數 直接擷取有效位數 如 將值2784....
Oracle中的內建函式在sql中的轉換整理
程式裡面經常會即支援oracle資料庫,又支援sql資料庫。而有些oracle內建函式用的比較多,但在sql中語法有些不同,我做了些整理,希望可以幫助大家。1.oracle中的內建函式 oracle 中的round函式 四捨五入 sql也可以用 oracle 中的trunc返回的是當天日期的 00 ...
Oracle中的內建函式在sql中的轉換整理
程式裡面經常會即支援oracle資料庫,又支援sql資料庫。而有些oracle內建函式用的比較多,但在sql中語法有些不同,我做了些整理,希望可以幫助大家。1.oracle中的內建函式 oracle 中的round函式 四捨五入 sql也可以用 oracle 中的trunc返回的是當天日期的 00 ...