instr函数
同义词 instr一般指instr函数
instr是一个非常好用的字符串处理函数,几乎所有的字符串分隔都用到此函数。instr函数在Oracle/PLSQL中是返回要截取的字符串在源字符串中的位置。
- 中文名
- instr截取函数
- 外文名
- instr
- 作 用
- 返回要截取的字符串
- 类 型
- 字符串处理函数
- 可选参数
- start
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
位置索引号从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
1
|
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 函数来查找某字符串在另一个字符串中首次出现的位置。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
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。 |
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步