public List<T> findAllByPage(Class<T> tClass, Date startTime, Date endTime, int page, int size, Map<String, String> searchMap){ Criteria where = new Criteria(); if (startTime != null && endTime != null){ where.andOperator(Criteria.where("clickTime").gte(startTime),Criteria.where("clickTime").lte(endTime)); } for (Map.Entry<String, String> entry : searchMap.entrySet()) { where.andOperator(Criteria.where("\""+ entry.getKey() +"\"").gte(entry.getValue())); } Query query = new Query(where); query.skip((page - 1) * size).limit(size); return mongoTemplate.find(query,tClass); } 上述代码问题在哪里?
时间: 2024-01-09 10:03:19 浏览: 124
上述代码的问题在于以下几点:
1. 在使用 Criteria 的 andOperator 方法拼接条件时,如果 searchMap 中有多个条件,应该使用 Criteria 的多个 and 方法拼接条件,而不是多次调用 andOperator 方法。
2. 在使用 Criteria 拼接条件时,如果需要使用双引号包含字段名,应该使用 Criteria.where 方法的第一个参数来指定字段名,而不是直接在字符串中添加双引号。
3. 在使用 Criteria 拼接条件时,如果需要使用大于等于或小于等于的比较符号,应该使用 Criteria 的 gte 和 lte 方法,而不是使用大于号和小于号。
4. 在调用 mongoTemplate.find 方法时,应该将 tClass 作为第一个参数传入。
下面是修改后的代码:
```
public List<T> findAllByPage(Class<T> tClass, Date startTime, Date endTime, int page, int size, Map<String, String> searchMap) {
Criteria where = new Criteria();
if (startTime != null && endTime != null) {
where.andOperator(Criteria.where("clickTime").gte(startTime), Criteria.where("clickTime").lte(endTime));
}
for (Map.Entry<String, String> entry : searchMap.entrySet()) {
where.and(Criteria.where(entry.getKey()).gte(entry.getValue()));
}
Query query = new Query(where);
query.skip((page - 1) * size).limit(size);
return mongoTemplate.find(query, tClass);
}
```
阅读全文