gpt4 book ai didi

mysql - 无法找到一种方法来否定模式内的正则表达式

转载 作者:行者123 更新时间:2023-11-29 07:28:57 25 4
gpt4 key购买 nike

我找不到使用正则表达式查找包含第一个单词第二个 单词的所有匹配项的方法,但是在这两个单词之间不应该 是一个特定的词。

select '<p>66-155</p><p>en application</p>' regexp '66-155.*[<,p,>]en application'

应该返回 0

select '<p>66-155 en application</p>' regexp '66-155.*[<,p,>]en application'

应该返回 1

最佳答案

在 8.0 之前的 MySQL 版本中,您不能为此使用单个正则表达式,因为它是基于 POSIX 的正则表达式,不支持环视。

对于早期版本的 MySQL,您可以使用类似的东西

LIKE '%66-155%en application%' AND NOT LIKE '%66-155%<p>%en application%'

如果您有正则表达式模式而不是文字子字符串,那么它看起来像

REGEXP '66-155.*en application' AND NOT REGEXP '66-155.*<p>.*en application'

在 MySQL 8.x 中,借助 ICU 正则表达式引擎,您可以使用基于环视的正则表达式:

REGEXP '66-155(?:(?!<p>).)*?en application'

(?:(?!<p>).)*?tempered greedy token(?s) 匹配的任何字符(除换行符字符外,要匹配包括换行符在内的任何字符,请在模式开头添加 .) , 尽可能少的重复(由于 *? 量词),这不会启动 <p>字符序列。

关于mysql - 无法找到一种方法来否定模式内的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52487606/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com