instr(目标字段,目标字符串,起始参数,匹配参数次数)
- 作用:instr函数返回要截取的字符串在源字符串中的位置。只检索一次,也就是说从字符的开始到字符的结尾就结束。
- 语法:instr(源字符串, 目标字符串, 起始位置, 匹配序号)
- demo:
select instr('helloeorld','l') from dual; -- 返回结果:3 默认第一次出现"l"的位置
select instr('helloworld','lo') from dual; -- 返回结果:4 即:在"lo"中,"lo"开始出现的位置select instr('helloworld','l',3,2) from dual; -- 返回结果:4 也就是说:在"helloworld"的第3(l)号位置开始,查找第二次出现的“l”的位置
select instr('helloworld','l',4,2) from dual; --返回结果:9 也就是说:在"helloworld"的第4(l)号位置开始,查找第二次出现的“l”的位置
regexp_substr(目标字段,正则规则,起始参数,匹配参数次数,模式)
- 语法:
function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)
__srcstr :需要进行正则处理的字符串
__pattern :进行匹配的正则表达式
__position :起始位置,从第几个字符开始正则表达式匹配(默认为1)
__occurrence :标识第几个匹配组,默认为1
__modifier :模式('i'不区分大小写进行检索;'c'区分大小写进行检索。默认为'c'。)
instr(源字符串, 目标字符串, 起始位置, 匹配序号)
demo:
select regexp_substr(v.name, '[^,]', 1, 2) AS 子串 from v; -- 结果 KING FORD
oracle中的替换函数replace和translate函数
translate
- 语法:TRANSLATE(char, from, to)
- 用法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。
若from比to字符串长,那么在from中比to中多出的字符将会被删除。
三个参数中有一个是空,返回值也将是空值。
demo:
select translate('abcdefga','abc','wo') 返回值 from dual; -- 返回值 wodefgw
- 分析:该语句要将'abcdefga'中的'abc'转换为'wo',
由于'abc'中'a'对应'wo'中的'w',
故将'abcdefga'中的'a'全部转换成'w';
而'abc'中'b'对应'wo'中的'o',
故将'abcdefga'中的'b'全部转换成'o';
'abc'中的'c'在'wo'中没有与之对应的字符,
故将'abcdefga'中的'c'全部删除;
简单说来,就是将from中的字符转换为to中与之位置对应的字符,
若to中找不到与之对应的字符,返回值中的该字符将会被删除。
在实际的业务中,可以用来删除一些异常数据,
比如表a中的一个字段t_no表示电话号码,
而电话号码本身应该是一个由数字组成的字符串,
为了删除那些含有非数字的异常数据,
就用到了translate函数:
delete from a
where
length(
translate(trim(a.t_no),'0123456789' || a.t_no,'0123456789')
) <> length( trim(a.t_no) );
2.replace
- 语法:REPLACE(char, search_string,replacement_string)
- 用法:将char中的字符串search_string全部转换为字符串replacement_string。
- demo:
select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;
-- 返回值 fgsgswsgs
select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
-- 返回值 fgeeerrrtttsweeerrrttts
分析:第一个例子中由于'fgsgswsgs'中没有与'fk'匹配的字符串,
故返回值仍然是'fgsgswsgs';
第二个例子中将'fgsgswsgs'中的字符串'sg'全部转换为'eeerrrttt'。