微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – Spring MongoDB按字符串搜索id

我有一个使用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;
....
}

当我使用“id”/“_ id”作为列名时,即使我将有效字符串作为关键字发送,它也不会返回任何内容.我试过的示例查询如下

id in db - 560299fe627942619bcfdc87
keyword - 560

这有解决方案吗?提前致谢

解决方法:

我认为这不会起作用.
MongoDb ID不是String,而是ObjectId,可以表示为String但不作为一个字符串处理.
因此,对ObjectId执行正则表达式意味着mongo必须将每个ObjectId解包为String,然后对其执行正则表达式.这将是疯狂的低效率.

除非Spring-data-mongo有自己的想法,否则你可能需要重新考虑你的模型和查询.

因为这是MongoDB在ObjectId上执行正则表达式的一个奇怪的用例.
你能解释为什么你这样做以及你为什么不使用另一个字段来进行正则表达式?

亲切的问候
克里斯

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐