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