Oracle中字段為空處理成0

2021-07-14 03:08:35 字數 1395 閱讀 1884

oracle資料庫中的函式

a :表名, b: 要修改的欄位名

執行效果如下:

decode函式的用法

作用是--顯示的時候變了  資料庫真實資料不變啊

含**釋:

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語句。1 增加乙個字段 增加欄位時,只能排在已有欄位的後面,不能插到已有字段之間 alter table 表名 add 欄位名稱 字段型別 2 增加兩個字段 alter table 表名 add 欄位名稱 字段型別,欄位名稱 字段型別 二 修改乙個字段 cr...

Oracle中判斷字段是否為數字

在我們平常的開發中可能會遇到這樣的問題,就是判斷某一列是否全部由數字組成,我們都知道oracle並沒有給我們提供這樣乙個現成的函式,那麼根據我的經驗我總結了兩個行之有效的方法 列名 column,表名 table 1.使用trim translate函式 select from table wher...

Oracle中判斷字段是否為數字

在我們平常的開發中可能會遇到這樣的問題,就是判斷某一列是否全部由數字程式設計客棧組成,我們都知道oracle並沒有給我們提供這樣乙個現成的函式,那麼根據我的經驗我總結了兩個行之有效的方法 列名 column,表名 table 1.使用trim translate函式 複製 如下 select fro...