Oracle中的替换函数Replace和Translate函数

 1 1.translate
 2 语法:TRANSLATE(char, from, to)
 3 用法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。
 4             若from比to字符串长,那么在from中比to中多出的字符将会被删除。
 5             三个参数中有一个是空,返回值也将是空值。
 6 举例:SQL> select translate('abcdefga','abc','wo') 返回值 from dual;
 7             返回值
 8             -------
 9             wodefgw
10 分析:该语句要将'abcdefga'中的'abc'转换为'wo',
11             由于'abc''a'对应'wo'中的'w',
12             故将'abcdefga'中的'a'全部转换成'w';
13'abc''b'对应'wo'中的'o',
14             故将'abcdefga'中的'b'全部转换成'o';
15             'abc'中的'c''wo'中没有与之对应的字符,
16             故将'abcdefga'中的'c'全部删除;
17             简单说来,就是将from中的字符转换为to中与之位置对应的字符,
18             若to中找不到与之对应的字符,返回值中的该字符将会被删除。
19             在实际的业务中,可以用来删除一些异常数据,
20             比如表a中的一个字段t_no表示电话号码,
21             而电话号码本身应该是一个由数字组成的字符串,
22             为了删除那些含有非数字的异常数据,
23             就用到了translate函数:
24             SQL> delete from a,
25                       where length(translate(trim(a.t_no),
26                                             '0123456789' || a.t_no,
27                                             '0123456789')) <> length(trim(a.t_no));
28 
29 
30 2.replace
31 语法:REPLACE(char, search_string,replacement_string)
32 用法:将char中的字符串search_string全部转换为字符串replacement_string。
33 举例:SQL> select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;
34             返回值
35             ---------
36             fgsgswsgs
37             SQL> select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
38             返回值
39             -----------------------
40             fgeeerrrtttsweeerrrttts
41 分析:第一个例子中由于'fgsgswsgs'中没有与'fk'匹配的字符串,
42             故返回值仍然是'fgsgswsgs'43             第二个例子中将'fgsgswsgs'中的字符串'sg'全部转换为'eeerrrttt'44 总结:综上所述,replace与translate都是替代函数,
45          只不过replace针对的是字符串,而translate针对的是单个字符。

 

posted @ 2022-02-16 20:43  每天进步多一点  阅读(471)  评论(0编辑  收藏  举报