ouyang_gan 2023-03-16 02:23 采纳率: 60%
浏览 121
已结题

oracle如何利用正则去除字符串中括号及括号里内容?只能是首个括号

遇到一个需求疑问,要去除字符串里括号及括号里内容,正则应该可以,但是如何指定只匹配第一个括号呢?

  • 写回答

1条回答 默认 最新

  • manylinux 2023-03-16 02:34
    关注

    Oracle可以使用正则表达式函数REGEXP_REPLACE()来去除字符串中的括号及括号里的内容。以下是一个示例代码,演示如何去除字符串中的首个括号及括号里的内容:

    SELECTREGEXP_REPLACE('abc(def)ghi', '\(.*?\)', '') FROM dual;
    

    上述代码中,第一个参数是需要替换的字符串,第二个参数是正则表达式,用来匹配字符串中的括号及括号里的内容。其中,\(\)分别代表左括号和右括号,\.代表匹配任意字符,*代表匹配零个或多个字符,?代表匹配模式是非贪婪模式。

    \(\)需要使用反斜杠进行转义,否则它们会被解释为正则表达式中的特殊字符。

    上述代码执行结果为:

    abcghi
    

    可以看到,结果字符串中的首个括号及括号里的内容已经被成功去除。

    需要注意的是,如果字符串中含有多个括号,上述正则表达式只会去除第一个括号及括号里的内容。如果需要去除所有括号及括号里的内容,可以使用\([^)]*\)作为正则表达式。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    1人已打赏
    ouyang_gan 2023-03-16 02:56

    非常感谢!

    1
    回复
    manylinux 回复 ouyang_gan 2023-03-16 03:08

    不客气~~

    回复
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 3月23日
  • 已采纳回答 3月16日
  • 创建了问题 3月16日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部