1

我必须创建一个正则表达式,我需要用 NULL 替换 ORACLE 中动态查询的所有单词,但以 @ 字符开头的单词除外。例如:

SQL:

SQL: SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50

使用 REGEXP_REPLACE

DECLARE
    vl_result VARCHAR2(1000);
BEGIN
    vl_result := REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50', 'EXP_REG', '');
    dbms_output.put_line(vl_result);
END;

应该有以下结果:

@param1@param2@code@param4

并用各种方法试了几个,还是不行。

他们知道你能不能做到这一点??以及正则表达式的严重程度。

我正在处理 PL / SQL

4

2 回答 2

4

以下适用于给定的示例:

select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50', '.*?((@[^ ,]+)|$)', '\1') new_str
from   dual;

NEW_STR                   
--------------------------
@param1@param2@code@param4
于 2016-06-17T15:22:33.913 回答
1

这也使用反向引用,并适用于您的示例:

select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50',
  '[^@]?(@[[:alnum:]]+)?', '\1')
from dual;

REGEXP_REPLACE('SELECT@PAR
--------------------------
@param1@param2@code@param4

同样的事情也适用于 PL/SQL(当然@boneists 也是如此):

set serveroutput on
DECLARE
    vl_result VARCHAR2(1000);
BEGIN
    vl_result := REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50',
        '[^@]?(@[[:alnum:]]+)?', '\1');
    dbms_output.put_line(vl_result);
END;
/

PL/SQL procedure successfully completed.

@param1@param2@code@param4
于 2016-06-17T15:28:12.063 回答