[每日一题] OCP1z0-047 :2013-08-01 正则表达式--- REGEXP_REPLA
转载请注明出处:http://www.52php.cn/article/p-getsvitq-dk.html 这题又是考正则表达式,我们先根据题意,操作如下: hr@OCM> col "PHONE NUMBER" for a50 hr@OCM> SELECT phone_number,REGEXP_REPLACE(phone_number,'([[:digit:]]{3}).([[:digit:]]{3}).([[:digit:]]{4})','(1) 2-3') "PHONE NUMBER" 2 FROM employees; PHONE_NUMBER PHONE NUMBER -------------------- -------------------------------------------------- 650.507.9833 (650) 507-9833 650.507.9844 (650) 507-9844 515.123.4444 (515) 123-4444 011.44.1644.429264 011.44.1644.429264 011.44.1644.429263 011.44.1644.429263 011.44.1644.429262 011.44.1644.429262 省略结果。。。。。 650.501.4876 (650) 501-4876 650.507.9811 (650) 507-9811 650.507.9822 (650) 507-9822 107 rows selected. 根据查询结果可以得出正确答案是:C ************************************************************* REGEXP_REPLACE函数 让我们首先看一下传统的REPLACE SQL函数,它把一个字符串用另一个字符串来替换。假设您的数据在正文中有不必要的空格,您希望用单个空格来替换它们。利用REPLACE函数,您需要准确地列出您要替换多少个空格。然而,多余空格的数目在正文的各处可能不是相同的。下面的示例在Joe和Smith之间有三个空格。REPLACE函数的参数指定要用一个空格来替换两个空格。在这种情况下,结果在原来的字符串的Joe和Smith之间留下了一个额外的空格。 SELECT REPLACE('Joe Smith',' ',' ') AS replace FROM dual REPLACE --------- Joe Smith REGEXP_REPLACE函数把替换功能向前推进了一步,其语法在表 9中列出。以下查询用单个空格替换了任意两个或更多的空格。( )子表达式包含了单个空格,它可以按{2,}的指示重复两次或更多次。 SELECT REGEXP_REPLACE('Joe Smith','( ){2,}',' ') AS RX_REPLACE FROM dual RX_REPLACE ---------- Joe Smith 后向引用 正则表达式的一个有用的特性是能够存储子表达式供以后重用;这也被称为后向引用(在表 10 中对其进行了概述)。它允许复杂的替换功能,如在新的位置上交换模式或显示重复出现的单词或字母。子表达式的匹配部分保存在临时缓冲区中。缓冲区从左至右进行编号,并利用digit 符号进行访问,其中digit 是 1 到 9 之间的一个数字,它匹配第digit 个子表达式,子表达式用一组圆括号来显示。 接下来的例子显示了通过按编号引用各个子表达式将姓名 Ellen Hildi Smith 转变为 Smith,Ellen Hildi。
SELECT REGEXP_REPLACE( 'Ellen Hildi Smith','(.*) (.*) (.*)','3,1 2') FROM dual REGEXP_REPLACE('EL ------------------ Smith,Ellen Hildi 该 SQL 语句显示了用圆括号括住的三个单独的子表达式。每一个单独的子表达式包含一个匹配元字符 (.),并紧跟着 * 元字符,表示任何字符(除换行符之外)都必须匹配零次或更多次。空格将各个子表达式分开,空格也必须匹配。圆括号创建获取值的子表达式,并且可以用digit 来引用。第一个子表达式被赋值为 1 ,第二个 2,以此类推。这些后向引用被用在这个函数的最后一个参数 (3,1 2) 中,这个函数有效地返回了替换子字符串,并按期望的格式来排列它们(包括逗号和空格)。表 11 详细说明了该正则表达式的各个组成部分。 后向引用对替换、格式化和代替值非常有用,并且您可以用它们来查找相邻出现的值。接下来的例子显示了使用REGEP_SUBSTR 函数来查找任意被空格隔开的重复出现的字母数字值。显示的结果给出了识别重复出现的单词is 的子字符串。
SELECT REGEXP_SUBSTR( 'The final test is is the implementation',([[:alnum:]]+)([[:space:]]+)1') AS substr FROM dual SUBSTR ------ is is 来自官方文档:
Purpose
This function complies with the POSIX regular expression standard and the Unicode Regular Expression Guidelines. For more information,please refer toAppendix C,"Oracle Regular Expression Support".
Examples The following example examines
SELECT REGEXP_REPLACE(phone_number,'(1) 2-3') "REGEXP_REPLACE" FROM employees; REGEXP_REPLACE -------------------------------------------------------------------------------- (515) 123-4567 (515) 123-4568 (515) 123-4569 (590) 423-4567 . . . The following example examines country_name . Oracle puts a space after each non-null character in the string.
SELECT REGEXP_REPLACE(country_name,'(.)','1 ') "REGEXP_REPLACE" FROM countries; REGEXP_REPLACE -------------------------------------------------------------------------------- A r g e n t i n a A u s t r a l i a B e l g i u m B r a z i l C a n a d a . . . The following example examines the string,looking for two or more spaces. Oracle replaces each occurrence of two or more spaces with a single space.
SELECT REGEXP_REPLACE('500 Oracle Parkway,Redwood Shores,CA',' ') "REGEXP_REPLACE" FROM DUAL; REGEXP_REPLACE -------------------------------------- 500 Oracle Parkway,Redwood Shores,CA QQ:252803295 学习交流QQ群: MAIL:oracledba_cn@hotmail.com BLOG:http://blog.csdn.net/guoyjoe WEIBO:http://weibo.com/guoyJoe0218 ITPUB:http://www.itpub.net/space-uid-28460966.html OCM: http://education.oracle.com/education/otn/YGuo.HTM (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |