首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >是否可以在PL/SQL函数中使用正则表达式?

是否可以在PL/SQL函数中使用正则表达式?
EN

Stack Overflow用户
提问于 2017-05-24 22:26:00
回答 2查看 98关注 0票数 1

我正在编写一个简单的PL/SQL来格式化员工CUIL (社会保障ID),问题是我想要替换一个o多一个'-‘或'/’或空格表示一个简单的‘’,我的代码对于空格和'/‘都很好,但是我对另一个没有运气。你能帮帮我吗?谢谢

代码语言:javascript
复制
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;

起作用的例子

不起作用的示例

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-05-25 10:55:09

这应该作为一个regexp_replace - '([ /-]+)', '-'工作。

例如:

代码语言:javascript
复制
select regexp_replace('///  98   //////   46134679    1', '([ /-]+)', '-')
  from dual

返回-98-46134679-1

这将匹配一个或多个指定字符,并使用单个-替换它们。

票数 0
EN

Stack Overflow用户

发布于 2017-05-25 00:35:20

这会让你开始:

代码语言:javascript
复制
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;

它产生了这样的结果:

代码语言:javascript
复制
BEFORE                      FORMATTED
98     46134679////  1      98-46134679-1
98 ////// 46134679  1       98-46134679-1

我基本上是在数据的一部分周围使用括号的集合,然后选择括号1中匹配的信息,然后是一个破折号,括号3中匹配的信息,然后是一个破折号,然后是括号5中匹配的信息。您可以先执行这个函数,然后检查结果的长度,等等。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44169452

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档