Redshift 正则表达式匹配直到模式匹配但不包含模式

Posted

技术标签:

【中文标题】Redshift 正则表达式匹配直到模式匹配但不包含模式【英文标题】:Redshift regular expression match up until pattern match but not include pattern 【发布时间】:2017-07-12 23:09:41 【问题描述】:

由于 Redshift 不支持前瞻断言,我需要一种方法来查找子字符串模式匹配,但是,我希望在不包括模式本身的情况下包含模式匹配的字符串。

是的,作为替代方案,我当然可以使用 substring(),但是,如果没有匹配的子字符串,我仍然希望返回完整的字符串。这种方法需要使用 sever case 语句并且不适合。

使用正则表达式是理想的 - 例如:

The quick brown fox jumped over the lazy dog
Match String: jumped
Desired output would be:  The quick brown fox

【问题讨论】:

【参考方案1】:

如果你有一个固定的字符串——而且真的不需要正则表达式——只需使用split_part()

select split_part('the quick brown fox jumps', 'jump', 1)

【讨论】:

以上是关于Redshift 正则表达式匹配直到模式匹配但不包含模式的主要内容,如果未能解决你的问题,请参考以下文章

正则表达式:匹配模式后跟一个空格但不匹配2个或更多空格或EOF

Amazon Redshift 中匹配序列数字的正则表达式

正则表达式匹配所有字符直到到达字符,但也包括最后一个匹配

正则表达式与特定模式完全匹配 10 位数字

Redshift:如何从字符串列表中匹配最长的正则表达式字符串

匹配模式,但不返回所有模式