zoukankan      html  css  js  c++  java
  • sql常用函数instr()和substr()

    Decode

    decode(条件,值1,翻译值1,值2,翻译值2,...,缺省值) 该函数与程序中的 If...else if...else 意义一样

    NVL

    格式:NVL( string1, replace_with)

    功能:如果string1为NULL,则NVL函数返回replace_with的值,否则返回string1的值,如果两个参数都为NULL ,则返回NULL。

    注意事项:string1和replace_with必须为同一数据类型,除非显式的使用TO_CHAR函数进行类型转换。

    select nvl(sum(t.dwxhl),1) from tb_jhde t 就表示如果sum(t.dwxhl) = NULL 就返回 1

    Oracle在NVL函数的功能上扩展,提供了NVL2函数

    NVL2

    nvl2 (E1, E2, E3) 的功能为:如果E1为NULL,则函数返回E3,否则返回E2

    结合

    Decode 和 NVL等函数 常常结合使用,例如

    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中

    可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符。

    其语法为:
    instr(sourceString,destString,start,appearPosition).   instr('源字符串' , '目标字符串' ,'开始位置','第几次出现')
    其中sourceString代表源字符串;

    destString代表想聪源字符串中查找的子串;

    start代表查找的开始位置,该参数可选的,默认为1;

    appearPosition代表想从源字符中查找出第几次出现的destString,该参数也是可选的,默认为1;


    如果start的值为负数,那么代表从右往左进行查找,但是位置数据仍然从左向右计算。

    返回值为:查找到的字符串的位置。

    对于instr函数,我们经常这样使用:从一个字符串中查找指定子串的位置。例如:
    SQL> select instr('yuechaotianyuechao','ao') position from dual;

    POSITION
    ----------
             6

    从第7个字符开始搜索
    SQL> select instr('yuechaotianyuechao','ao', 7) position from dual;

    POSITION
    ----------
            17

    从第1个字符开始,搜索第2次出现子串的位置
    SQL> select instr('yuechaotianyuechao','ao', 1, 2) position from dual;

    POSITION
    ----------
            17

     注意:1。若‘起始位置’=0 时返回结果为0,
               2。这里只有三个参数,意思是查找第一个要查找字符的位置(因为 ‘第几次出现’默认为1),
    当‘起始位置’不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果‘起始位置’大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……(但是也是以第一个字符开始计数)

    substr函数的用法,取得字符串中指定起始位置和长度的字符串  ,默认是从起始位置到结束的子串。

     substr( string, start_position, [ length ] )       substr('目标字符串',开始位置,长度)
    如:
         substr('This is a test', 6, 2)     would return 'is'
         substr('This is a test', 6)     would return 'is a test'
         substr('TechOnTheNet', -3, 3)     would return 'Net'
         substr('TechOnTheNet', -6, 3)     would return 'The'select substr('Thisisatest', -4, 2) value from dual 

     -------------------------------------------------------------------------------------------------

    关于Instr()和substr()函数-

    INSTR共有4个参数;具体格式为:
    INSTR(strings|express,strings[,m,[n]])
    在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
    strings|express 被搜索的字符串
    strings 希望搜索的字符串
    m 搜索的开始位置,默认为1
    n 第n次出现希望搜索的字符串的位置,默认为1
    1.被搜索的字符串可以为字符串,也可以为表达式
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','i') result from dual;
    RESULT
    ----------
    7
    SQL> select instr(initcap('my 2 firefly')||'b','Fi') result from dual;
    RESULT
    ----------
    6


    2.希望搜索的字符串可以为字符或数字字符,(希望搜索的字符串长度可以1个或多个)
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','i') result from dual;
    RESULT
    ----------
    7
    SQL> select instr('my 2 firefly','iref') result from dual;
    RESULT
    ----------
    7
    SQL> select instr('my 2 firefly',2) result from dual;
    RESULT
    ----------
    4
    SQL> select instr('my 2 firefly',22) result from dual;
    RESULT
    ----------
    0


    3.m表示要从第几个字符开始查找
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',1) result from dual;
    RESULT
    ----------
    6
    注意:若m=0时返回结果为0
    select instr('my 2 firefly','f',0) result from dual;
    RESULT
    ----------
    0


    注意:这里只有三个参数,意思是查找第一个要查找字符的位置(因为n默认为1),
    当m不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果m大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',1) result from dual;
    RESULT
    ----------
    6
    SQL> select instr('my 2 firefly','f',3) result from dual;
    RESULT
    ----------
    6
    SQL> select instr('my 2 firefly','f',6) result from dual;
    RESULT
    ----------
    6
    SQL> select instr('my 2 firefly','f',7) result from dual;
    RESULT
    ----------
    10
    SQL> select instr('my 2 firefly','f',10) result from dual;
    RESULT
    ----------
    10


    当m大于要查找字符的最大的位置时,返回0


    QUOTE:
    SQL> select instr('my 2 firefly','f',11) result from dual;
    RESULT
    ----------
    0
    SQL> select instr('my 2 firefly','f',110) result from dual;
    RESULT
    ----------
    0


    反之亦然,若m<0,则表示从右向左来查找数据


    QUOTE:
    SQL> select instr('my 2 firefly','f',-1) result from dual;
    RESULT
    ----------
    10
    SQL> select instr('my 2 firefly','f',-2) result from dual;
    RESULT
    ----------
    10
    SQL> select instr('my 2 firefly','f',-4) result from dual;
    RESULT
    ----------
    6
    SQL> select instr('my 2 firefly','f',-40) result from dual;
    RESULT
    ----------
    0


    4.n表示要找第n个该字符
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',1,1) result from dual;
    RESULT
    ----------
    6
    SQL> select instr('my 2 firefly','f',1,2) result from dual;
    RESULT
    ----------
    10
    SQL> select instr('my 2 firefly','f',1,3) result from dual;
    RESULT
    ----------
    0


    当n大于查找源中包含所要查找字符串的最大个数时,返回0
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',1,4) result from dual;
    RESULT
    ----------
    0
    SQL> select instr('my 2 firefly','f',1,40) result from dual;
    RESULT
    ----------
    0


    当m<0时,表示从右向左查找,如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',-10,1) result from dual;
    RESULT
    ----------
    0
    SQL> select instr('my 2 firefly','f',-8,1) result from dual;
    RESULT
    ----------
    0
    SQL> select instr('my 2 firefly','f',-3,1) result from dual;
    RESULT
    ----------
    10


    注意:当m不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果m大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……
    如:


    QUOTE:
    SQL> select instr('my 2 firefly','f',-4,1) result from dual;
    RESULT
    ----------
    6
    等同于:
    SQL> select instr('my 2 firefly','f',-1,2) result from dual;
    RESULT
    ----------
    6
    另注意:如果要查找的字符串为 NULL时,返回NULL
    如:
    SQL> select instr('my 2 firefly',null,-1,2) result from dual;
    RESULT
    ----------
    SQL> select instr('my 2 firefly',null) result from dual;
    RESULT
    ----------
    SQL> select instr('my 2 firefly',null,1) result from dual;
    RESULT
    ----------


    QUOTE:
    ================================================


    字符串截取函数substr(strings|express,m,[n])
    strings|express 被截取的字符串或字符串表达式
    m 从第m个字符开始截取
    n 截取后字符串长度为n
    1.被截取的为字符串或字符串表达式


    QUOTE:
    SQL> select substr(upper('abcde'),1,2) from dual;
    SUBSTR(UPPER('ABCDE'),1,2)
    --------------------------
    AB
    SQL> select substr('abcde',1,2) from dual;
    SUBSTR('ABCDE',1,2)
    -------------------
    ab


    2.如果m<0,则表示从右向左截取
    这里如果n>0,若n>=|m|,截取字符串长度为|m|个(从右向左截取),
    若n<|m|,截取字符串长度为n个(从右向左截取)
    如:


    QUOTE:
    SQL> select substr('abcde',-4,2) from dual;
    SUBSTR('ABCDE',-4,2)
    --------------------
    bc
    SQL> select substr('abcde',-4,1) from dual;
    SUBSTR('ABCDE',-4,1)
    --------------------
    b
    SQL> select substr('abcde',-4,4) from dual;
    SUBSTR('ABCDE',-4,4)
    --------------------
    bcde
    SQL> select substr('abcde',-4,5) from dual;
    SUBSTR('ABCDE',-4,5)
    --------------------
    bcde
    SQL> select substr('abcde',-4,50) from dual;
    SUBSTR('ABCDE',-4,50)
    ---------------------
    bcde


    如果m<0,n=0结果为NULL:


    QUOTE:
    SQL> select substr('abcde',-4,0) from dual;
    SUBSTR('ABCDE',-4,0)
    --------------------
    SQL> select substr('abcde',-5,0) from dual;
    SUBSTR('ABCDE',-5,0)
    --------------------


    如果m<0,n<0结果为NULL:


    QUOTE:
    SQL> select substr('abcde',-2,0) from dual;
    SUBSTR('ABCDE',-2,0)
    --------------------
    SQL> select substr('abcde',-2,-1) from dual;
    SUBSTR('ABCDE',-2,-1)
    ---------------------
    SQL> select substr('abcde',-2,-4) from dual;
    SUBSTR('ABCDE',-2,-4)
    ---------------------
    SQL> select substr('abcde',-3,-4) from dual;
    SUBSTR('ABCDE',-3,-4)
    ---------------------


    3.如果n<=0,,结果为0:


    QUOTE:
    SQL> select substr('abcde',1,-4) from dual;
    SUBSTR('ABCDE',1,-4)
    --------------------
    SQL> select substr('abcde',1,-2) from dual;
    SUBSTR('ABCDE',1,-2)
    --------------------
    SQL> select substr('abcde',1,0) from dual;
    SUBSTR('ABCDE',1,0)
    -------------------
    SQL> select substr('abcde',1,-2) from dual;
    SUBSTR('ABCDE',1,-2)
    --------------------


    4.m,n只要有一个为NULL,那么结果为NULL


    QUOTE:
    SQL> select substr('abcde',1,null) from dual;
    SUBSTR('ABCDE',1,NULL)
    ----------------------
    SQL> select substr('abcde',null,null) from dual;
    SUBSTR('ABCDE',NULL,NULL)
    -------------------------
    SQL> select substr('abcde',null,1) from dual;
    SUBSTR('ABCDE',NULL,1)
    ----------------------


    5.不用n参数时:
    n=NULL里,结果为NULL
    n>=0,结果为从n个字符开始截取到最后


    QUOTE:
    SQL> select substr('abcde',null) from dual;
    SUBSTR('ABCDE',NULL)
    --------------------
    SQL> select substr('abcde',0) from dual;
    SUBSTR('ABCDE',0)
    -----------------
    abcde
    SQL> select substr('abcde',1) from dual;
    SUBSTR('ABCDE',1)
    -----------------
    abcde
    SQL> select substr('abcde',2) from dual;
    SUBSTR('ABCDE',2)
    -----------------
    bcde


    n<0时,如果|n|<=被截取字符串的长度,
    结果为从右向左截取|n|个字符


    QUOTE:
    SQL> select substr('abcde',-2) from dual;
    SUBSTR('ABCDE',-2)
    ------------------
    de
    SQL> select substr('abcde',-3) from dual;
    SUBSTR('ABCDE',-3)
    ------------------
    cde
    SQL> select substr('abcde',-5) from dual;
    SUBSTR('ABCDE',-5)
    ------------------
    abcde


    如果|n|>被截取字符串的长度,结果为NULL

    QUOTE:
    SQL> select substr('abcde',-6) from dual;
    SUBSTR('ABCDE',-6)
    ------------------
    SQL> select substr('abcde',-60) from dual;

  • 相关阅读:
    关于10月20日#8的六道题的心得与感悟
    关于10月19日#7的六道题的心得与感悟
    关于10月17日#6的五道数据结构题的心得与感悟
    关于10月16日模拟赛的心得与感悟
    关于10月15日#5的四道图论题的心得与感悟
    关于10月14日#4的四道图论题的心得与感悟
    关于跨进程通信AIDL的一些总结
    对App应用架构搭建的一些思考
    Java 实例化接口或抽象类
    使用ViewPager实现卡片叠加效果
  • 原文地址:https://www.cnblogs.com/sylvandu/p/5732919.html
Copyright © 2011-2022 走看看