我有一个使用mongodb的简单弹簧网页应用程序.我需要按字符串搜索集合id,其中字符串应该使用正则表达式语句.我的标准创建方法如下所示.public Criteria getSearchCriteriaQuery(String keyword, String colomnArray[]...
我有一个使用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上执行正则表达式的一个奇怪的用例.
你能解释为什么你这样做以及你为什么不使用另一个字段来进行正则表达式?
亲切的问候
克里斯
本文标题为:java – Spring MongoDB按字符串搜索id
基础教程推荐
- MyBatis加载映射文件和动态代理的实现 2023-07-15
- 基于Java实现连连看游戏的示例代码 2023-05-13
- plantuml画图实现代码画时序图UML用例图 2023-03-11
- 详解MybatisPlus中@Version注解的使用 2023-01-13
- 如何使用mybatis-plus实现分页查询功能 2023-01-23
- SpringBoot参数校验Validator框架详解 2023-01-09
- SpringBoot项目找不到javax.servlet.Filter的问题及解决 2023-02-27
- Spring Cloud根据服务名获取服务的ip端口问题 2023-05-14
- SpringBoot整合Mybatis与druid实现流程详解 2023-06-23
- springboot 正确的在异步线程中使用request的示例代码 2023-03-06