共计 2602 个字符,预计需要花费 7 分钟才能阅读完成。
首先便是这 Trim 函数。Trim 函数具有删除任意指定字符的功能,而去除字符串首尾空格则是 trim 函数被使用频率最高的一种。语法 Trim (string),参数 string:string 类型,指定要删除首部和尾部空格的字符串返回值 String。函数执行成功时返回删除了 string 字符串首部和尾部空格的字符串,发生错误时返回空字符串(””)。如果参数值为 null 时,会抛出空指针异常。在 Oracle 中,trim 使用的形式多为人 rtrim() 与 ltrim() 两种,分别为去除字符串右边空格与去除字符串左边空格。
当然 trim 的功能不止如此,下面进行细致的介绍,这里我多以去除字符串空格为例。
我们看下 trim 函数的语法描述:trim([ { {leading|trailing|both} [trim_character]|trim_character} from] trim_source
1)、不使用任何参数
SQL> select trim(‘ 11 ‘) aa from dual;
AA
—
11
这是最常见的一种使用方法,都使用默认的参数,默认情况下 TRIM 会同时删除字符串前后出现的空格。
2)、使用 both 参数,效果等同于方法一不使用任何参数
SQL> select trim(both from ‘ 11 ‘) aa from dual;
AA
—
11
“BOTH”参数表示同时去除字符串前后所指定的内容(默认情况下删除空格)。
3)、使用 leading 与 trailing 参数
SQL> select trim(leading from ‘ 11 ‘) aa from dual;
AA
—-
11
SQL> select trim(trailing from ‘ 11 ‘) aa from dual;
AA
—–
11
从结果中得分隔符 ’-‘,可以发现使用 leading 参数可以去除字符串右端的空格,而 trailing 参数则可以去除字符串左端的空格。正如 oracle 提供的 rtrim() 与 ltrim()。
4)、使用 trim_character 参数
trim_character 参数改变了“删除空格”的默认行为。如果想要删除字符串 ’xxxxWORLDxxxx’ 前后出现的“x”,“trim_character”参数就派上用场了。
SQL> select trim(‘x’ from ‘xxxxWORLDxxxx’) aaaaa from dual;
AAAAA
—–
WORLD
trim_character 配合“both”、“trailing”和“leading”三个参数使用效果如下,与之前演示类似。看结果,不赘述。
SQL> select trim(‘x’ from ‘xxxxWORLDxxxx’) aaaaa from dual;
AAAAA
—–
WORLD
SQL> select trim(both ‘x’ from ‘xxxxWORLDxxxx’) aaaaa from dual;
AAAAA
—–
WORLD
SQL> select trim(trailing ‘x’ from ‘xxxxWORLDxxxx’) aaaaa from dual;
AAAAA
———
xxxxWORLD
SQL> select trim(leading ‘x’ from ‘xxxxWORLDxxxx’) aaaaa from dual;
AAAAA
———
WORLDxxxx
必须注意的一点是这里的“trim_character”参数只允许包含一个字符,不支持多字符。trim 不能满足我们去除多字符要求,但是我们可以使用 rtrim 和 ltrim 来处理。
1)使用 rtrim
SQL> select rtrim(‘ORxxxxWORLDxxxxOR’,’OR’) aaaaa from dual;
AAAAA
—————
ORxxxxWORLDxxxx
2)使用 ltrim
SQL> select ltrim(‘ORxxxxWORLDxxxxOR’,’OR’) aaaaa from dual;
AAAAA
—————
xxxxWORLDxxxxOR
3)联合使用 RTRIM 和 LTRIM 函数达到我们的目的
SQL> select rtrim(ltrim(‘ORxxxxWORLDxxxxOR’,’OR’),’OR’) aaaaa from dual;
AAAAA
————-
xxxxWORLDxxxx
使用 rtrim 和 ltrim 函数时的注意事项:“OR”不表示整个“OR”字符串进行匹配,而是发现任意的字符“O”或字符“R”均做删除操作。
对于 trim 函数的应用就介绍到,下面介绍一下 replace 函数,个人觉得 replace 函数在去空格时更好用。replace 函数用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。来看下 replace 函数的语法描述:replace(‘string_replace1′,’string_replace2′,’string_replace3’)
‘string_replace1’ 待搜索的字符串表达式,string_replace1 可以是字符数据或二进制数据。
‘string_replace2’ 待查找的字符串表达式,string_replace2 可以是字符数据或二进制数据。
‘string_replace3’ 替换用的字符串表达式,string_replace3 可以是字符数据或二进制数据。
返回类型,如果 string_replace(1、2 或 3)是支持的字符数据类型之一,则返回字符数据;如果 string_replace(1、2 或 3)是支持的 binary 数据类型之一,则返回二进制数据。
这里我们依然以去空格为例。
SQL> select replace(‘ aa kk ‘,’ ‘,”) abcd from dual;
ABCD
—-
aakk
与使用 trim 函数的结果进行对比,我们可以发现,使用 replace 函数不仅可以去除字符串两端的空格,也可去除字符串内部的空格。
当然,如果只是要去除字符串两端的空格,使用 trim 函数效率会更高
更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-02/140615.htm