oracle MVP

InStr函數實現代碼減肥

檢測字符串中是否包含一個元音字母: 
1、普通的方法: 

If UCase$(char) = "A" Or UCase$(char) = "E" Or UCase$(char) = "I" Or UCase$(char) = "O" Or UCase$(char) = "U" Then 

’ it is a vowel 

End If 

2、更加簡練的方法: 

InStr("AaEeIiOoUu", char)

同樣,通過單詞中沒有的字符作爲分界符,使用InStr來檢查變量的內容。下面的例子檢查Word中是否包含一個季節的名字: 1、普通的方法: 

ILCase$(word) = "winter" Or LCase$(word) = "spring" Or LCase$(word) = _ "summer" Or LCase$(word) = "fall"
2、更加簡練的方法: 

If Instr(";winter;spring;summer;fall;", ";" & word & ";") Then 

’ it is a season’s name 

End If

有時候,甚至可以使用InStr來替代Select 

Case代碼段,但一定要注意參數中的字符數目。下面的例子中,轉換數字0到9的相應英文名稱爲阿拉伯數字: 1、普通的方法: 
Select Case LCase$(word) 

Case "zero" 

result = 0 

Case "one" 

result = 1 

Case "two" 

result = 2 

Case "three" 

result = 3 

Case "four" 

result = 4 

Case "five" 

result = 5 

Case "six" 

result = 6 

Case "seven" 

result = 7 

Case "eight" 

result = 8 

Case "nine" 

result = 9 

End Select 

2、更加簡練的方法:

result = InStr(";zero;;one;;;two;;;three;four;;five;;six;;;seven;eight;nine;", ";" & LCase$(word) & ";") / 6

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

1、比較大小

2、表、視圖結構轉化

多時候需要將行轉換成列或者將列轉換成行來顯示數據,而往往我們在建立表結構時不能根據顯示的要求來保存數據,於是乎只能在保存數據之後做一些必要的操作(比方說:建立視圖等)來達到顯示的目的。

現有一個商品銷售表sale,表結構爲:
month    char(6)      --月份
sell    number(10,2)   --月銷售金額

現有數據爲:
200001  1000
200002  1100
200003  1200
200004  1300
200005  1400
200006  1500
200007  1600
200101  1100
200202  1200
200301  1300

想要轉化爲以下結構的數據:
year   char(4)      --年份
month1  number(10,2)   --1月銷售金額
month2  number(10,2)   --2月銷售金額
month3  number(10,2)   --3月銷售金額
month4  number(10,2)   --4月銷售金額
month5  number(10,2)   --5月銷售金額
month6  number(10,2)   --6月銷售金額
month7  number(10,2)   --7月銷售金額
month8  number(10,2)   --8月銷售金額
month9  number(10,2)   --9月銷售金額
month10  number(10,2)   --10月銷售金額
month11  number(10,2)   --11月銷售金額
month12  number(10,2)   --12月銷售金額

結構轉化的SQL語句爲:
create or replace view
v_sale(year,month1,month2,month3,month4,month5,month6,month7,month8,month9,month10,month11,month12)
as
    select
    substrb(month,1,4),
    sum(decode(substrb(month,5,2),'01',sell,0)),
    sum(decode(substrb(month,5,2),'02',sell,0)),
    sum(decode(substrb(month,5,2),'03',sell,0)),
    sum(decode(substrb(month,5,2),'04',sell,0)),
    sum(decode(substrb(month,5,2),'05',sell,0)),
    sum(decode(substrb(month,5,2),'06',sell,0)),
    sum(decode(substrb(month,5,2),'07',sell,0)),
    sum(decode(substrb(month,5,2),'08',sell,0)),
    sum(decode(substrb(month,5,2),'09',sell,0)),
    sum(decode(substrb(month,5,2),'10',sell,0)),
    sum(decode(substrb(month,5,2),'11',sell,0)),
    sum(decode(substrb(month,5,2),'12',sell,0))
    from sale
    group by substrb(month,1,4);

 

 

a(字段)
01,02
01,03
01,04,02
02
01,02,03,04
02,04


就這麼一個字段 求如何通過sql統計出
01出現的次數
02出現的次數
03 出現的次數
04出現的次數

一個sql語句實現

select sum(case InStr(a,'01') when 0 then 0 else 1 end) as num01 ,
sum(case InStr(a,'02') when 0 then 0 else 1 end) as num02,
sum(case InStr(a,'03') when 0 then 0 else 1 end) as num03,
sum(case InStr(a,'04') when 0 then 0 else 1 end) as num04,
sum(case InStr(a,'05') when 0 then 0 else 1 end) as num from test

select sum(decode(InStr(a,'01'),0,0,1)) as num01 ,
sum(decode(InStr(a,'02'),0,0,1)) as num02,
sum(decode(InStr(a,'03'),0,0,1)) as num03,
sum(decode(InStr(a,'04'),0,0,1)) as num04,
sum(decode(InStr(a,'05'),0,0,1)) as num from test

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