加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle 正则表达式的一次使用经历

发布时间:2020-12-12 14:01:27 所属栏目:百科 来源:网络整理
导读:主要是在数据加工处理中使用: 数据处理过程如下: CREATE OR REPLACE PROCEDURE P_DEAL_CMS_DOC IS CURSOR C_DEAL IS SELECT L.*, REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(L.TITLE, '鄂青发+.*?+[0-9]*+.*?+号'), '鄂青[联办]发+.*?+

主要是在数据加工处理中使用:


数据处理过程如下:


CREATE OR REPLACE PROCEDURE P_DEAL_CMS_DOC IS

CURSOR C_DEAL IS
SELECT L.*,
REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(L.TITLE,
'鄂青发+.*?+[0-9]*+.*?+号'),
'鄂青[联办]发+.*?+[0-9]*+.*?+号'),
'鄂青发+.*?+[〔【]+[0-9]{4}+[〕】]+.*?+[0-9]*+.*?+号'),
'鄂青[联办]发+.*?+[〔【]+[0-9]{4}+[〕】]+.*?+[0-9]*+.*?+号') AS TITLE_NEW,
REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(L.CONTENT,
'鄂青[联办]发+.*?+[〔【]+[0-9]{4}+[〕】]+.*?+[0-9]*+.*?+号') AS CONTENT_NEW,
REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(REGEXP_REPLACE(L.SUMMARY,
'鄂青[联办]发+.*?+[〔【]+[0-9]{4}+[〕】]+.*?+[0-9]*+.*?+号') AS SUMMARY_NEW
FROM CMS_DOC L
WHERE L."TYPE" = 2
AND L.STATE = 4;

BEGIN
FOR V_DEAL IN C_DEAL LOOP
BEGIN
UPDATE CMS_DOC
SET TITLE = V_DEAL.TITLE_NEW,
CONTENT = V_DEAL.CONTENT_NEW,
SUMMARY = V_DEAL.SUMMARY_NEW
WHERE ID = V_DEAL.ID;
END;
END LOOP;

COMMIT;

END P_DEAL_CMS_DOC;

解释:1、.*? --匹配任意个数的空格字符;

2、[〔【] -- 匹配字符 〔 或者【;

3、[联办] -- 匹配汉字 '联'或者'办';

4、[0-9]* --匹配任意个数的数字。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读