Oracle截取字符串substr、查找字符串位置instr、替换字符串replace

1、截取字符串:substr

substr(str1,str2,str3)
str1为目标字符串;str2是将要输出的子串的起点;str3是将要输出的子串的长度    
例子:
substr('ABCDEFG', 2, 3)   =   'BCD'    
substr('ABCDEFG',   -2)   =   'FG'  --如果第二个参数为负数,那么将会从源串的尾部开始向前定位至负数的绝对值的位置
substr('ABCDEFG',   -4)   =   'DEFG

2、查找字符串位置:instr

instr(string, subString, [start_position, [nth_appearance]])
其中,string是元字符串;subString是要查找的子字符串;start_position是要查找的开始位置,为可选项(默认为1),注意在这里字符串索引从1开始,如果此参数为正,则从左到右检索,如果此参数为负,则从右到左检索;nth_appearance是元字符串中第几次出现的子字符串,此参数可选,缺省默认为1,如果是负数则系统报错。
例子:
instr('ABCDABCDAEF', 'AB');   -- 返回结果是:1,因为instr字符串索引从1开始,所以是1不是0
instr('ABCDABCDAEF', 'DA', 1, 2);   -- 返回结果是:8,返回第二次出现'DA'的位置
instr('A BCDABCDAEF', 'DA', 1, 2);  -- 返回结果是:9,由于我在元字符串中加了一个空格,空格仍然算一个字符


3、替换字符串:replace

replace(str1, str2, str3)
其表示的意思是:在str1中查找str2,凡是出现str2的地方,都替换成str3。
例子:
replace('ABCDEFG', 'CDE', 'cde');  -- 返回结果是:ABcdeFG
replace('ABCDEFG', 'CDE', '');   -- 返回结果是:ABFG,CDE被替换成空字符
replace('ABCDEFG', 'CDE');   -- 返回结果是:ABFG,当不存在第三个参数时,CDE直接被删掉------据此可以确定某个字符串在字符中出现的次数

4、replace扩展:
确定某个字符串在字符中出现的次数。
例子:
select a.* from tb_duty a where length(a.col)-length(replace(a.col, ',', ''))=n(n为出现的次数)

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用`INSTR`函数来查找包含多个字符的子字符串。该函数的语法如下: ``` INSTR(string, substring1 [, start_position [, occurrence [, substring2 ]]]) ``` 其中,`string`参数是要查找字符串,`substring1`参数是要查找的子字符串,`start_position`参数是可选的,表示从哪个位置开始查找,默认是1,`occurrence`参数也是可选的,表示要查找的子字符串出现的次数,默认是1,`substring2`参数也是可选的,表示要替换的子字符串。 例如,要查找包含多个字符的子字符串,可以使用以下语句: ``` SELECT INSTR('Hello world, how are you today?', 'world') FROM dual; ``` 该语句将返回子字符串"world"在原始字符串中的位置,即7。 要截取字符串中的一部分,可以使用`SUBSTR`函数。该函数的语法如下: ``` SUBSTR(string, start [, length]) ``` 其中,`string`参数是要截字符串,`start`参数是截的起始位置,`length`参数是可选的,表示要截的长度,默认是从起始位置字符串末尾。 例如,要截取字符串中的一部分,可以使用以下语句: ``` SELECT SUBSTR('Hello world, how are you today?', 7, 5) FROM dual; ``` 该语句将返回从原始字符串的第7个字符开始的5个字符,即"world"。 要替换字符串中的子字符串,可以使用`REPLACE`函数。该函数的语法如下: ``` REPLACE(string, substring1 [, substring2]) ``` 其中,`string`参数是要替换字符串,`substring1`参数是要被替换的子字符串,`substring2`参数是替换后的子字符串。 例如,要替换字符串中的子字符串,可以使用以下语句: ``` SELECT REPLACE('Hello world, how are you today?', 'world', 'everyone') FROM dual; ``` 该语句将返回将字符串中的"world"替换为"everyone"后的结果,即"Hello everyone, how are you today?"。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值