簡體   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