当前位置:文档之家› sql常用函数instr()和substr()

sql常用函数instr()和substr()

在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 搜索的开始位置,默认为1n 第n次出现希望搜索的字符串的位置,默认为11.被搜索的字符串可以为字符串,也可以为表达式如:QUOTE:SQL> select instr('my 2 firefly','i') result from dual;RESULT----------7SQL> select instr(initcap('my 2 firefly')||'b','Fi') result from dual;RESULT----------62.希望搜索的字符串可以为字符或数字字符,(希望搜索的字符串长度可以1个或多个)如:QUOTE:SQL> select instr('my 2 firefly','i') result from dual;RESULT----------7SQL> select instr('my 2 firefly','iref') result from dual;RESULT----------7SQL> select instr('my 2 firefly',2) result from dual;RESULT----------4SQL> select instr('my 2 firefly',22) result from dual;RESULT----------3.m表示要从第几个字符开始查找如:QUOTE:SQL> select instr('my 2 firefly','f',1) result from dual;RESULT----------6注意:若m=0时返回结果为0select instr('my 2 firefly','f',0) result from dual;RESULT----------注意:这里只有三个参数,意思是查找第一个要查找字符的位置(因为n默认为1),当m不大于要查找的第一个字符的位置时,返回的值都将是第一个字符的位置,如果m大于要查找的第一个字符的位置时,返回的值都将是第2个字符的位置,依此类推……如:QUOTE:SQL> select instr('my 2 firefly','f',1) result from dual;RESULT----------6SQL> select instr('my 2 firefly','f',3) result from dual;RESULT----------6SQL> select instr('my 2 firefly','f',6) result from dual;RESULT----------6SQL> select instr('my 2 firefly','f',7) result from dual;RESULT----------10SQL> select instr('my 2 firefly','f',10) result from dual; RESULT----------10当m大于要查找字符的最大的位置时,返回0QUOTE:SQL> select instr('my 2 firefly','f',11) result from dual; RESULT----------SQL> select instr('my 2 firefly','f',110) result from dual; RESULT----------反之亦然,若m<0,则表示从右向左来查找数据QUOTE:SQL> select instr('my 2 firefly','f',-1) result from dual; RESULT----------10SQL> select instr('my 2 firefly','f',-2) result from dual; RESULT----------10SQL> select instr('my 2 firefly','f',-4) result from dual; RESULT----------6SQL> select instr('my 2 firefly','f',-40) result from dual; RESULT----------4.n表示要找第n个该字符如:QUOTE:SQL> select instr('my 2 firefly','f',1,1) result from dual; RESULT----------6SQL> select instr('my 2 firefly','f',1,2) result from dual; RESULT----------10SQL> select instr('my 2 firefly','f',1,3) result from dual; RESULT----------当n大于查找源中包含所要查找字符串的最大个数时,返回0 如:QUOTE:SQL> select instr('my 2 firefly','f',1,4) result from dual; RESULT----------SQL> select instr('my 2 firefly','f',1,40) result from dual; RESULT----------当m<0时,表示从右向左查找,如:QUOTE:SQL> select instr('my 2 firefly','f',-10,1) result from dual; RESULT----------SQL> select instr('my 2 firefly','f',-8,1) result from dual; RESULT----------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 截取后字符串长度为n1.被截取的为字符串或字符串表达式QUOTE:SQL> select substr(upper('abcde'),1,2) from dual;SUBSTR(UPPER('ABCDE'),1,2)--------------------------ABSQL> select substr('abcde',1,2) from dual;SUBSTR('ABCDE',1,2)-------------------ab2.如果m<0,则表示从右向左截取这里如果n>0,若n>=|m|,截取字符串长度为|m|个(从右向左截取),若n<|m|,截取字符串长度为n个(从右向左截取)如:QUOTE:SQL> select substr('abcde',-4,2) from dual;SUBSTR('ABCDE',-4,2)--------------------bcSQL> select substr('abcde',-4,1) from dual;SUBSTR('ABCDE',-4,1)--------------------bSQL> select substr('abcde',-4,4) from dual;SUBSTR('ABCDE',-4,4)--------------------bcdeSQL> select substr('abcde',-4,5) from dual;SUBSTR('ABCDE',-4,5)--------------------bcdeSQL> 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,那么结果为NULLQUOTE: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里,结果为NULLn>=0,结果为从n个字符开始截取到最后QUOTE:SQL> select substr('abcde',null) from dual; SUBSTR('ABCDE',NULL)--------------------SQL> select substr('abcde',0) from dual; SUBSTR('ABCDE',0)-----------------abcdeSQL> select substr('abcde',1) from dual; SUBSTR('ABCDE',1)-----------------abcdeSQL> select substr('abcde',2) from dual; SUBSTR('ABCDE',2)-----------------bcden<0时,如果|n|<=被截取字符串的长度,结果为从右向左截取|n|个字符QUOTE:SQL> select substr('abcde',-2) from dual; SUBSTR('ABCDE',-2)------------------deSQL> select substr('abcde',-3) from dual; SUBSTR('ABCDE',-3)------------------cdeSQL> select substr('abcde',-5) from dual; SUBSTR('ABCDE',-5)------------------abcde如果|n|>被截取字符串的长度,结果为NULLQUOTE:SQL> select substr('abcde',-6) from dual;SUBSTR('ABCDE',-6)------------------SQL> select substr('abcde',-60) from dual;。

相关主题