trim,ltrim,rtrim函数用法
这类函数共有两种作用:这里的l和r字母可以理解成left和right,也可以记住它们的真实含义:leading和trailing——前面和后面
1)第一种,即大家都比较熟悉的去除空格
2)第二种,去除指定的字符。trim只能去除单个字符,而ltrim和rtrim可以去除多个字符。
trim去除字符的写法:
–表示字符串string2去除前面|后面|前后面(leading|trailing|both)的字符string1,默认去除方式为both
语法:SELECT TRIM(leading|trailing|both string1 FROM string2) FROM dual;
由以上测例可以看出:
去除过程会从第一个字符开始匹配,遇到无匹配则退出,因此不管从前面、后面或是前后一起处理,遇到B字符则退出处理过程,正中间的两个A字母都没有除去。
注:trim去除字符只能是单个字符,如下,要去除的字符若为字符集则报错
SQL> SELECT trim(trailing ‘12’ from ‘123dsq12’) FROM dual;
SELECT trim(trailing ‘12’ from ‘123dsq12’) FROM dual
ORA-30001: 截取集仅能有一个字符
ltrim和rtrim去除字符的写法:
–表示字符串string1去除前面与string2字符集匹配的,若无匹配则结束返回
SELECT ltrim(string1,string2) FROM dual;
–rtrim与ltrim类似,只是去除的是右边算起匹配的字符
SELECT rtrim(string1,string2) FROM dual;
这里string1表示的并不是完全匹配string1字符串的去除,而是string1内包含的所有字符都会被去除。