我有一个使用mongodb的简单弹簧网页应用程序。我需要按字符串搜索集合id,其中字符串应该使用正则表达式语句。我的标准创建方法如下所示。
public Criteria getSearchCriteriaQuery(String keyword, String colomnArray[]){
Criteria[] criteriaList = new Criteria[colomnArray.length];
for (int i=0; i<colomnArray.length; i++) {
criteriaList[i] = Criteria.where(colomnArray[i]).regex(keyword, "i");
}
return this.criteria.orOperator(criteriaList);
}
我的域名看起来像这样
@Document
public class sampleDomain{
@Id
private String id;
....
}
当我使用&#34; id&#34; /&#34; _id&#34;作为列名,即使我将有效字符串作为关键字发送,它也不会返回任何内容。我试过的示例查询在下面给出
id in db - 560299fe627942619bcfdc87
keyword - 560
有解决方案吗?提前致谢
答案 0 :(得分:1)
我认为这不会起作用。 MongoDb ID不是String,而是ObjectId,可以表示为String但不作为一个字符串处理。 因此,对ObjectId执行正则表达式意味着mongo必须将每个ObjectId解包为String,然后对其执行正则表达式。这将是疯狂的低效率。
除非Spring-data-mongo有任何想法,否则您可能需要重新考虑您的模型和查询。
因为这是MongoDB在ObjectId上执行正则表达式的一个奇怪的用例。 你能解释为什么你这样做以及为什么你不使用其他字段来进行正则表达式?
亲切的问候 克里斯