繁体   English   中英

如何在oracle sql查询中提取括号之间的字符串

[英]How to extract a string between brackets in oracle sql query

我正在尝试从字符串中提取括号之间的值。 我怎样才能做到这一点。

例如:我有这个字符串:Gupta, Abha (01792)

我想得到括号内的结果,即:01792

我正在尝试编写这样的查询:

select substr('Gupta, Abha (01792)',instr('Gupta, Abha (01792)','(')+1,5) from dual;

这实际上给了我结果。 但问题是括号之间的字符数不一定总是 5。

所以我想避免在查询中硬编码“5”。

有人可以让我知道如何使此查询更通用。

谢谢,艾卜哈

我们可以在这里尝试使用REGEXP_SUBSTR

SELECT REGEXP_SUBSTR('Gupta, Abha (01792)', '\((.+)\)', 1, 1, NULL, 1) FROM dual;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM