繁体   English   中英

在Mongodb中使用正则表达式

[英]Using regular Expressions with Mongodb

我正在使用Java Spring与Mongodb一起工作。 我需要找到描述字段中存在“经理”一词的文档。 我尝试了以下两种方法

方法1

Query query = new Query();
query.addCriteria(Criteria.where("discription").regex("/\bmanager\b/"));

方法2

Query query = new Query();
Pattern p = Pattern.compile("/\bmanager\b/");
query.addCriteria(Criteria.where("discription").regex(p));

但是这些都不起作用。 我用这样的mongodb控制台尝试过

db.test.find({discription: {$regex: /\bmanager\b/}})

它按我的预期工作。 我的Java代码有什么问题。

您不必在regex表达式中添加斜杠,因为regex方法会处理它。 所以

Query query = new Query();
query.addCriteria(Criteria.where("description").regex("\bmanager\b"));

应该管用。

看起来您可以直接使用正则表达式字符串,而无需使用Pattern.compile() 你有尝试过吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM