PL / SQL regexp_like过滤器

时间:2017-01-09 21:37:44

标签: regex oracle plsql oracle12c

我想删除一些表并编写此程序:

    set serveroutput on
    declare
        type namearray is table of varchar2(50);
        total integer;
        name namearray;
    begin
        --select statement here ..., please see below
        total :=name.count;
        dbms_output_line(total);

        for i in 1 .. total loop
        dbms_output.put_line(name(i));
        -- execute immediate 'drop table ' || name(i) || ' purge';
    End loop;
    end;
    /

我们的想法是删除所有具有如下模式的表名的表:

ERROR_REPORT[2 digit][3 Capital characters][10 digits]
example: ERROR_REPORT16MAY2014122748

但是,我无法想出正确的正则表达式。以下是我的选择陈述和结果:

select table_name bulk collect into name from user_tables where regexp_like(table_name, '^ERROR_REPORT[0-9{2}A-Z{3}0-9{10}]');

结果包括我需要的所有表名以及ERROR_REPORT311AUG20111111111。这不应该出现在结果中。

以下select语句显示相同的结果,这意味着A-Z {3}对正则表达式没有影响。

select table_name bulk collect into name from user_tables where regexp_like(table_name, '^ERROR_REPORT[0-9{2}0-9{10}]');

我的问题是什么是正确的正则表达式,以及我的错误是什么?

谢谢,

亚历

2 个答案:

答案 0 :(得分:1)

正确的正则表达式是

'^ERROR_REPORT[0-9]{2}[A-Z]{3}[0-9]{10}'

答案 1 :(得分:0)

我认为这个正则表达式应该有效:

^ERROR_REPORT[0-9]{2}[A-Z]{3}[0-9]{10}

但是,请查看regex101链接。我假设您在ERROR_REPORT之后需要2位数,但您的示例名称显示为3。