1

我正在研究 MySQL 数据库,并注意到它本身并不支持 PCRE(需要插件)。

我希望将这三个用于一些数据验证(这些实际上是赋予pattern属性的值):

  1. ^[A-z\. ]{3,36}
  2. ^[a-z\d\.]{3,24}$
  3. ^(?=^.{4,}$)(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?!.*\s).*$

我该怎么做呢?
我在网上查看,但找不到任何具体的例子或答案。此外,似乎不存在可以自动执行此操作的实用程序。

我知道有时,这样的转换并不准确,可能会产生差异,但我愿意尝试。

4

1 回答 1

3

MySQL 文档指出:

MySQL 使用 Henry Spencer 的正则表达式实现,旨在符合 POSIX 1003.2。MySQL 使用扩展版本REGEXP来支持在 SQL 语句中使用运算符执行的模式匹配操作。

好的,所以我们正在谈论 POSIX ERE。

此页面列出了各种正则表达式之间的详细信息,因此我将其用作备忘单。


  1. ^[A-z\. ]{3,36}

    您正在使用:

    • 锚点:^
    • 字符类:[...]
    • 范围量词:{n,m}

    所有这些都在 POSIX ERE 中开箱即用地支持,因此您可以按原样使用此表达式。但是在字符类中转义.是多余的,并且在字符类中A-z很可能是错误的(它包括[\]^_\`),所以只需编写:

    ^[A-Za-z. ]{3,36}
    
  2. ^[a-z\d\.]{3,24}$

    这个\d也使用,它在 POSIX ERE 中不受支持。所以你必须写:

    ^[a-z0-9.]{3,24}$
    
  3. ^(?=^.{4,}$)(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?!.*\s).*$

    嗯。您正在使用前瞻。这些完全超出了 POSIX ERE 的范围,但您可以通过组合几个 SQL 子句以获得等效逻辑来解决此限制:

    WHERE LENGTH(foo) >= 4
      AND foo REGEXP '[0-9]'
      AND foo REGEXP '[a-z]'
      AND foo REGEXP '[A-Z]'
      AND NOT foo REGEXP '[ \t\r\n]'
    
于 2015-03-09T21:03:50.190 回答