admin 管理员组

文章数量: 1087139


2024年4月18日发(作者:springcloud改造成dubbo)

在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

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个字符的位置,

依此类推……(但是也是以第一个字符开始计数)

从第7个字符开始搜索

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;


本文标签: 位置 字符串 字符