我正在编写一个简单的PL/SQL来格式化员工CUIL (社会保障ID),问题是我想要替换一个o多一个'-‘或'/’或空格表示一个简单的‘’,我的代码对于空格和'/‘都很好,但是我对另一个没有运气。你能帮帮我吗?谢谢
CREATE OR REPLACE FUNCTION formatear_cuit_cuil(p_cuit_cuil VARCHAR2)
RETURN VARCHAR2
IS
v_length VARCHAR2(50) := p_cuit_cuil;
BEGIN
IF
LENGTH(REGEXP_REPLACE(v_length, '[/ | |.]+')) <> 11 THEN
RETURN 'El CUIT/CUIL no tiene el largo correcto';
END IF;
IF
REGEXP_LIKE(
p_cuit_cuil,
'^[0-9][0-9][ /-]+[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][ /-]+[0-9]$'
) THEN
RETURN REGEXP_REPLACE(p_cuit_cuil, '/+| +', '-');
ELSE
RETURN 'CUIT/CUIL no tiene el formato correcto';
END IF;
EXCEPTION
WHEN OTHERS THEN
RETURN 'Error al formatear CUIT/CUIL';
END formatear_cuit_cuil;起作用的例子

不起作用的示例

发布于 2017-05-25 10:55:09
这应该作为一个regexp_replace - '([ /-]+)', '-'工作。
例如:
select regexp_replace('/// 98 ////// 46134679 1', '([ /-]+)', '-')
from dual返回-98-46134679-1
这将匹配一个或多个指定字符,并使用单个-替换它们。
发布于 2017-05-25 00:35:20
这会让你开始:
with a as (
select '98 46134679////1' as before from dual
union all
select '98 ////// 46134679 1' as before from dual
)
select a.before,
regexp_replace(a.before,
'^([0-9][0-9])([ /-])+([0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9])([ /-]+)([0-9])$',
'\1-\3-\5') as formatted from a;它产生了这样的结果:
BEFORE FORMATTED
98 46134679//// 1 98-46134679-1
98 ////// 46134679 1 98-46134679-1我基本上是在数据的一部分周围使用括号的集合,然后选择括号1中匹配的信息,然后是一个破折号,括号3中匹配的信息,然后是一个破折号,然后是括号5中匹配的信息。您可以先执行这个函数,然后检查结果的长度,等等。
https://stackoverflow.com/questions/44169452
复制相似问题