oracle MVP

本文介绍了InStr函数在多种场景下的高效使用方法,包括检测字符串中的特定字符、简化选择语句、统计特定子串出现次数等,展示了如何利用此函数减少代码复杂度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值