首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EJBQL/MySQL正则表达式和IN

EJBQL/MySQL正则表达式和IN
EN

Stack Overflow用户
提问于 2010-12-30 21:12:23
回答 2查看 268关注 0票数 2

我有一个正则表达式的列表,并希望返回那些带有一个字段的行,该字段可以传递任何正则表达式。有没有类似下面这样的东西:

代码语言:javascript
复制
SELECT * FROM Foo as f WHERE f.bar IN ("regex1","regex2");

看起来在EJBQL中根本不可能使用正则表达式,所以我猜我必须使用原生(MySQL)查询。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-12-30 21:33:57

为什么不把正则表达式组合成一个呢?

代码语言:javascript
复制
"(?:" + regex1 + ")|(?:" + regex2 + ")"

所以如果regex1 = "^.*foo(.*)bar"regex2 = "baz(.*)frob$",你会得到

代码语言:javascript
复制
(?:^.*foo(.*)bar)|(?:baz(.*)frob$)
票数 2
EN

Stack Overflow用户

发布于 2010-12-30 21:33:05

不,这不可能。至少不是你想的那样。

改为这样做:将正则表达式作为行插入到表中。然后查询

代码语言:javascript
复制
SELECT 
  * 
FROM
  Foo AS f
  INNER JOIN Regexes AS re ON f.bar REGEXP re.pattern
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4562860

复制
相关文章

相似问题

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