如何使用 mongoDB 条件查询在 java 中获得更干净的代码
how to get more clean code in java with mongoDB criteria query
我在 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));
}
想到的只有这个方法,但是条件越多代码越乱。有没有更好的方法?
如果你有像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);
你可以试试这个:
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);
我在 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));
}
想到的只有这个方法,但是条件越多代码越乱。有没有更好的方法?
如果你有像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);
你可以试试这个:
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);