sql常用函数-instr()

  2016-07-26 17:39

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

其语法为: instr(sourceString,destString,start,appearPosition).

instr('源字符串' , '目标字符串' ,'开始位置','第几次出现')

其中sourceString代表源字符串;

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

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

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

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

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

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

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

QUOTE: SQL> select instr('my 2 firefly','f',1) result from dual;

RESULT

----------

6

3.1注意:若m=0时返回结果为0

select instr('my 2 firefly','f',0) result from dual;

RESULT

----------

0

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

QUOTE: SQL> select instr('my 2 firefly','f',3) result from dual;

RESULT

----------

6

SQL> select instr('my 2 firefly','f',10) result from dual;

RESULT

----------

10

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

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

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

QUOTE: SQL> select instr('my 2 firefly','f',-1) 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

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

如: SQL> select instr('my 2 firefly','f',1,40) result from dual;

RESULT

----------

0

4.2当m<0时,表示从右向左查找,如:(同3.2)

QUOTE: 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

5.另注意:如果要查找的字符串为 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

----------

 

================================================

你好,游客!(点击更改信息)

您的电子邮件不会被公布,带*为必填。


  • *

    code

      正在提交中,请稍候...
      评论提交成功
    回复 的评论,点击取消回复。