正则表达式 IN SQL
Regular Expression IN SQL
我必须制作一个正则表达式,我需要用 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
以下适用于给定示例:
select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50', '.*?((@[^ ,]+)|$)', '') new_str
from dual;
NEW_STR
--------------------------
@param1@param2@code@param4
这也是 uses a back reference,适用于您的示例:
select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50',
'[^@]?(@[[:alnum:]]+)?', '')
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:]]+)?', '');
dbms_output.put_line(vl_result);
END;
/
PL/SQL procedure successfully completed.
@param1@param2@code@param4
我必须制作一个正则表达式,我需要用 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
以下适用于给定示例:
select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50', '.*?((@[^ ,]+)|$)', '') new_str
from dual;
NEW_STR
--------------------------
@param1@param2@code@param4
这也是 uses a back reference,适用于您的示例:
select REGEXP_REPLACE('SELECT @param1, column2, column3, @param2 FROM dual WHERE @code = code_table AND amount > @param4 + 50',
'[^@]?(@[[:alnum:]]+)?', '')
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:]]+)?', '');
dbms_output.put_line(vl_result);
END;
/
PL/SQL procedure successfully completed.
@param1@param2@code@param4