我想删除一些表并编写此程序:
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}]');
我的问题是什么是正确的正则表达式,以及我的错误是什么?
谢谢,
亚历
答案 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。