在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

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。