Oracle截取字符串substr、查找字符串位置instr、替换字符串replace
1、截取字符串:substr
2、查找字符串位置:instr
3、替换字符串:replace
4、replace扩展:
确定某个字符串在字符中出现的次数。
例子:
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为出现的次数)
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: JS判断输入中是否包含中文字符
- 下一篇: mysql取差集、交集、并集