看完这章你会掌握以下内容。
- INSTR 和 SUBSTR 经典组合套用场景
- TRIM,LTRIM,RTRIM 不带参数和带参数的区别
- Replace 函数替换不存在的字符,是否报错
-
- *
INSTR函数语法(C1,C2,I,J)
在一个字符串中搜索指定的字符,返回发现指定的字符的位置;
C1 被搜索的字符串
C2 希望搜索的字符串
I 搜索的开始位置,默认为1,可正可负(正向逆向)
J 出现的位置,默认为1
SQL> select instr("abcde",'b'); 结果是2,即在字符串“abcde”里面,字符串“b”出现在第2个位置。如果没有找到,则返回0;不可能返回负数
SBUSTR(str,pos);
就是从pos开始的位置,一直截取到最后。还有一种比较常用的是:
SUBSTR(str,pos,len);
这种表示的意思是,就是从pos开始的位置,截取len个字符(空白也算字符),pos默认为1。
经典练习题1:
从字符串中'1#qfq#3df#520#d234#dlaj#' 查找第3个#号和第4个#号之间的字符串
两个函数的嵌套使用,Substr和Instr
Substr 截取字符
Instr 查找字符所在位置,返回位置数值。
SUBSTR('1#qfq#3df#520#d234#dlaj#', 起始位置, 截取长度)
INSTR('1#qfq#3df#520#d234#dlaj#','#',1,3)+1 --起始位置
INSTR('1#qfq#3df#520#d234#dlaj#','#',1,4)-INSTR('1#qfq#3df#520#d234#dlaj#','#',1,3)-1 -- 截取长度
SELECT SUBSTR('1#qfq#3df#520#d234#dlaj#',
INSTR('1#qfq#3df#520#d234#dlaj#','#',1,3)+1,
INSTR('1#qfq#3df#520#d234#dlaj#','#',1,4)-
INSTR('1#qfq#3df#520#d234#dlaj#','#',1,3)-1)
FROM dual;
经典练习题2:
从字符串中'dfas#dffr#saf#fdad#fsfa#ds#dfa' 查找最后一个#号后面的字符串
select substr('dfas#dffr#saf#fdad#fsfa#ds#dfa',Instr('dfas#dffr#saf#fdad#fsfa#ds#dfa','#',-1,1)+1 )from dual
select instr('ds#as#dfa','#',-1,1) from dual; -- 计数位置方向始终从左往右
select substr('ds#as#dfa',6) FROM DUAL;
LTrim,Trim,RTrim 函数本身有两种用法,一是不带参数,二是带参数。
-- TRIM 函数的基本用法:
SELECT TRIM(' AS '),LTRIM(' AS '),RTRIM(' AS ') FROM DUAL;
SELECT TRIM(' A S ')FROM DUAL;
- 不带截取参数,就是截取字符串里的空格。
- 如果字符中间出现空格,则不能清除。
如果带截取参数的则要注意以下几项:|
1. 区分大小写,如果不一致,则无法截取。
2. 截取参数并不是按照既定有的顺序进行截取,而是截取到参数里没有出现的字符串才停止
例如: 以下第三行例子,一直截取到没有出现任意一个截取参数为止。ABC之后还有一长段的C都满足截取字段的条件,直到出现了第一个不是的字符串D,则往后的才保留下来。
SELECT LTRIM('abcddee','abc') FROM DUAL; --- 返回 ddee
SELECT LTRIM('abcddee','ABC') FROM DUAL; --- 返回 abcddee
SELECT LTRIM('ABCCCCDDEE','ABC') FROM DUAL; ---- 返回 DDEE
SELECT LTRIM('ACDCCCCBDE','ABC') FROM DUAL; ---- 返回 DCCCCCBDE
3.Replace 函数,如果出现需要替换的字符不在原来的字符串里,直接运行,不会报错
SELECT REPLACE(REPLACE('a你好djl','a','3'),'b','4') FROM dual;
发布于 05-30