首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将Perl正则表达式转换为SQL正则表达式

将Perl正则表达式转换为SQL正则表达式
EN

Stack Overflow用户
提问于 2016-11-04 08:40:18
回答 2查看 621关注 0票数 0

我需要在Firebird数据库中使用Perl正则表达式。

Firebird通过提供一个-condition来支持正则表达式。不幸的是,Firebird中的SQL正则表达式语法与Perl语法不同。

是否有可能将Perl正则表达式转换为SQL正则表达式?i不需要完全兼容,但至少应该可以转换量词和字符类。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-11-04 12:06:02

我使用了以下替换规则(顺序重要)将大多数Perl正则表达式转换为SQL语法:

首先,必须转义SQL特殊字符:

  1. _ > \_
  2. % > \%

然后,必须替换Perl特殊字符和字符类。

  1. . > _
  2. \d> [:digit:]
  3. \D > [^[:digit:]]
  4. \w > [^[:whitespace:]]
  5. \W > [:whitespace:]
  6. \s > [:whitespace:]
  7. \S > [^[:whitespace:]]

注意:这里使用默认的Perl转义字符\来表示SIMILAR TO

请放心,用更多的可能的替代来扩展我的回答。

票数 1
EN

Stack Overflow用户

发布于 2016-11-04 08:55:17

我不需要完全兼容,但至少数量和字符类应该是可转换的。

幸运的是,您可以在 regex syntax中使用字符类、?*+{exact_occurrences_number}{min,}{min,max}量词。

唯一的问题是Unicode类别/属性类,您只能在那里使用POSIX字符类:

<predefined class name> ::= ALPHA | UPPER | LOWER | DIGIT | ALNUM | SPACE | WHITESPACE

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40418312

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档