oracle中instr函数的参数,oracle中instr函数用法

http://www.itjxue.com  2023-01-05 16:15  来源:未知  点击次数: 

oracle中查找一个字符串中某个字符的位置是什么函数

instr函数为字符查找函数,其功能是查找一个字符串在另一个字符串中首次出现的位置。instr函数在Oracle/PLSQL中是返回要截取的字符串在源字符串中的位置。

int

index=

instr(“abcd”,

'c');

index=

扩展资料:

注意

位置索引号从1开始。

如果String2在String1中没有找到,instr函数返回0。

示例:

SELECT

instr('syranmo','s')

FROM

dual;

--

返回

1

SELECT

instr('syranmo','ra')

FROM

dual;

--

返回

3

SELECT

instr('syran

mo','at',1,2)

FROM

dual;

--

返回

0。

参考资料来源:百度百科-instr函数

Oracle | 字符串操作 - SUBSTR 和 INSTR函数

一、字符串查找函数? INSTR()

二、字符串截取函数 SUBSTR()

三、实际应用: SUBSTR 和 INSTR 结合使用

例:(1) INSTR('todayisabeautifulday' , 'to')??

???????????????? 返回结果:1 (因为字符串索引号从1开始,所以返回1,不是返回0)

??? ? (2)? INSTR('todayisabeautifulday' , 'day',1, 1)

? ? ???????????? 返回结果: 3 (返回第一次查出 day 的位置)

????? (3) 若改成 INSTR('todayisabeautifulday' , 'day',1, 2)

??????????????? 则返回结果为第二次出现 day 的位置:18

????? (4) INSTR('today is a beautiful day' , 'is',1, 1)

??????????????? 返回结果:7 (空格也是一个字符)

例:(1)SUBSTR ('ABCDEFG', 2, 3)

??????????????? 返回结果:'BCD' (从第2个字符开始,截取长度为3的子串)

?????? (2)substr('ABCDEFG',? -2)?

??????????????? 返回结果:'FG'?? (从倒数第2个字符开始,截取到源串的末尾)

?????? (3)substr('ABCDEFG', -4, 2)

?????????????? 返回结果:'DE' (从倒数第4个字符开始,截取长度为2的子串)

????? (4)substr('ABCDEFG', 4, -1)

?????????????? 返回结果: 空字符串 (截取长度小于1时,返回空字符串?)

结合 SUBSTR()和 INSTR()来实现截取字符串中特定字符前后的字符串

(1)截取 “hello,world” 字符串中 “,” 分隔符之前的字符串

(2)截取 “hello,world, ye” 字符串中第1次出现的 “,” 字符和第2次出现的 “,” 字符之间的字符串

参考链接:

instr函数怎么用?

InStr([start, ]string1, string2[, compare])

其中:

start:设置开始查找的位置,可以省略,省略时默认从第一个字符开始查找,

string1是源字符

string2可以说是关键字

最后一个compare别管他啥2进制,一般找字符串就理解为是否区分大小写,如你的例题,返回6的那句,把他的值设为1,就是不区分大小写,因为是从第四个字符开始往后找,而且不区分大小写,所以返回值才是6

还如你的例子,返回值是9的那句,

MyPos = Instr(1, SearchString, SearchChar, 0)

这句的意思是,从第一个字符开找,并且compare是0,就是区分大小写,所以第9个字符是大写P,所以返回值是9。

扩展资料

instr( string1, string2, start_position,nth_appearance )

参数

string1:源字符串,要在此字符串中查找。

string2:要在string1中查找的字符串 。

start_position:代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。

nth_appearance:代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。

instr函数

instr函数

instr函数为字符查找函数,其功能是查找一个字符串在另一个字符串中首次出现的位置。instr函数在Oracle/PLSQL中是返回要截取的字符串在源字符串中的位置。

IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"苏宁")0),"苏宁",IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"京东")0,"京东商城",""))AS 渠道

第一步:InStr(1,[2-2 激活机型刷新]![专卖店名],"苏宁")0

首先对字段的名称进行搜索 ,查找含有苏宁的记录

第二步:IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"苏宁")0),"苏宁"

IIF 函数对 查找结果进行判断,如果0 则说明 含有这个字符串

第三步:IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"苏宁")0),"苏宁",IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"京东")0,"京东商城",""))

IIF函数 嵌套使用 接着判断 京东 除这两者之外的 空着

第四步:IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"苏宁")0),"苏宁",IIf(InStr(1,[2-2 激活机型刷新]![专卖店名],"京东")0,"京东商城",""))AS 渠道

把以上结果 作为字符串 放到渠道字段下

本示例使用 InStr 函数来查找某字符串在另一个字符串中首次出现的位置。

DimSearchString,SearchChar,MyPos

SearchString="XXpXXpXXPXXP"'被搜索的字符串。

SearchChar="P"'要查找字符串"P"。

'-------------------------------------

'从第四个字符开始,以文本比较的方式找起。返回值为6(小写p)。

'小写p和大写P在文本比较下是一样的。

MyPos=Instr(4,SearchString,SearchChar,1)

'--------------------------------------

'从第一个字符开始,以二进制比较的方式找起。返回值为9(大写P)。

'小写p和大写P在二进制比较下是不一样的。

MyPos=Instr(1,SearchString,SearchChar,0)

'--------------------------------------

'缺省的比对方式为二进制比较(最后一个参数可省略)。

MyPos=Instr(SearchString,SearchChar)'返回9。

MyPos=Instr(1,SearchString,"W")'返回0。

(责任编辑:IT教学网)

更多

推荐Windows服务器文章