如何使用 mongoDB 条件查询在 java 中获得更干净的代码 [重复]

Posted

技术标签:

【中文标题】如何使用 mongoDB 条件查询在 java 中获得更干净的代码 [重复]【英文标题】:how to get more clean code in java with mongoDB criteria query [duplicate] 【发布时间】:2021-12-05 23:55:42 【问题描述】:

我正在用 java 编写 mongodb 查询

criteria.andOperator(Criteria.where("id").is(id),
         Criteria.where("name").is(name),
         Criteria.where("age").is(age),
         Criteria.where("address").is(address),
         Criteria.where("phonemun").is(phonenum));

我正在按上述方式编写查询代码。

criteria.andOperator(Criteria.where("id").is(id),
             Criteria.where("name").is(name));
if(age != null)
  criteria.andOperator(Criteria.where("age").is(age));

if(address != null)
  criteria.andOperator(Criteria.where("address").is(address));

if(phoneNum != null)
  criteria.andOperator(Criteria.where("phonenum").is(phoneNum));

这是唯一想到的方法,但是条件越多,代码就越乱。有没有更好的办法?

【问题讨论】:

我觉得不错 不确定这是否有帮助:docs.mongodb.com/manual/reference/operator/aggregation/ifNull 谢谢大家的回答。我通过参考***.com/questions/47907333/…解决了这个问题 【参考方案1】:

如果你有像addCriteria (Criteria crit, String fieldName, Object val)这样的方法

if (val != null) 
    criteria.andOperator(Criteria.where(fieldName).is(val));

那么你可以把逻辑放在这个方法中

addCriteria (criteria, "Age", age);
addCriteria (criteria, "Name", name);

【讨论】:

【参考方案2】:

你可以试试这个:

Map<String, Object> params = new HashMap<>();
params.put("id", id);
params.put("name", name);
params.put("age", value);    // value is Integer or null
// ...similarly for phoneNum, address, etc

Collection<Criteria> criterias = new ArrayList<>();

params.forEach((k, v) -> 
    if (v != null) 
        criterias.add(Criteria.where(k).is(v));
    
);

Criteria criteria = new Criteria().andOperator(criterias);

【讨论】:

以上是关于如何使用 mongoDB 条件查询在 java 中获得更干净的代码 [重复]的主要内容,如果未能解决你的问题,请参考以下文章

java mongodb查询条件

MongoDB批量更新不同查询条件的数据

java怎么做到使用mongodb来进行分组查询统

如何在mongodb的单个查询中添加具有不同条件输出的Multiple Group By?

mongoDB在java中怎么根据内嵌文档条件查询

如何利用spring data mongodb 进行多条件查询