看完这章你会掌握以下内容

  • 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. 不带截取参数,就是截取字符串里的空格。

  1. 如果字符中间出现空格,则不能清除。

如果带截取参数的则要注意以下几项:|
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


蜗牛
27 声望13 粉丝