instr函式为字元查找函式,其功能是查找一个字元串在另一个字元串中首次出现的位置。instr函式在Oracle/PLSQL中是返回要截取的字元串在源字元串中的位置。
基本介绍
- 中文名:instr
- 外文名:instr
- 作用:字元串查找
- 套用:VB,VBS,Oracle
- 可选参数:start
Oracle
语法
instr( string1, string2, start_position,nth_appearance )
参数
● string1:源字元串,要在此字元串中查找。
●string2:要在string1中查找的字元串 。
●start_position:代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字元串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字元串在源字元串中的开始索引。
●nth_appearance:代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。
注意
位置索引号从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
如果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

示例
1 select instr('helloworld','l') from dual; --返回结果:3 默认第一次出现“l”的位置2 select instr('helloworld','lo') from dual; --返回结果:4 即:在“lo”中,“l”开始出现的位置3 select instr('helloworld','wo') from dual; --返回结果:6 即“w”开始出现的位置
VB和VBS
函式原型
InStr([start,]string1,string2[,compare])
表达式
InStr([起始,] 接受搜寻的字元串,被搜寻的字元串[,匹配模式])
参数
- start
可选参数。为数值表达式,设定每次搜寻的起点。如果省略,将从第一个字元的位置开始。如果 start 包含 Null,将发生错误。如果指定了 compare 参数,则一定要有 start 参数。 - string1
必要参数。接受搜寻的字元串表达式。 - string2
必要参数。被搜寻的字元串表达式。 - compare
可选参数。指定字元串比较。如果 compare 是 Null,将发生错误。如果省略 compare,Option Compare 的设定将决定比较的类型。
Compare 参数设定为:
常数 | 值 | 描述 |
vbUseCompareOption | -1 | 使用Option Compare 语句设定执行一个比较。 |
vbBinaryCompare | 0 | 执行一个二进制比较(即 英文字元区分大小写)。 |
vbTextCompare | 1 | 执行一个按照原文的比较(即 英文字元不区分大小写)。 |
vbDatabaseCompare | -2 | 仅适用于Microsoft Access,执行一个基于资料库信息比较。 |
返回值
从 Start 位置开始,在 String1 中寻找 String2 ,如果没有找到,则返回0。如果 String1 或 String2 为Null,则返回Null,其他情况返回 String2 在 String1 中的起始位置。
示例
本示例使用 InStr 函式来查找某字元串在另一个字元串中首次出现的位置。
DimSearchString,SearchChar,MyPosSearchString="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。