在更新中使用regexp_replace

jij*_*ijo 2 regex sql oracle

我有一个db列report_name,它的值与此类似

000007091_PaymentRegisterReport _D x3A 975844_2012-12-26.XLS
Run Code Online (Sandbox Code Playgroud)

我需要在所有具有XLS扩展名的PaymentRegisterReport中删除_D之前的空格.有人可以帮我使用regex在update语句中使用regexp_replace函数吗?

Tec*_*hDo 11

你真的需要一个正则表达式来更新数据吗?请检查查询.

update TableName
set report_name=REPLACE(report_name, ' _D' , '_D')
WHERE report_name LIKE '%PaymentRegisterReport %' AND 
  report_name LIKE '%.XLS';
Run Code Online (Sandbox Code Playgroud)