【问题标题】:Regular Expression IN SQLSQL 中的正则表达式
【发布时间】:2016-10-19 11:18:03
【问题描述】:

我必须创建一个正则表达式,我需要用 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

【问题讨论】:

    标签: regex oracle plsql oracle10g regexp-replace


    【解决方案1】:

    以下适用于给定示例:

    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
    

    【讨论】:

    • 非常感谢
    【解决方案2】:

    这也是uses a back reference,适用于您的示例:

    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
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2010-12-30
      • 1970-01-01
      • 2018-08-02
      • 1970-01-01
      相关资源
      最近更新 更多