Commit 99507600 authored by wangsong's avatar wangsong

update query by days

parent 0f3a8f19
...@@ -50,7 +50,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St ...@@ -50,7 +50,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St
criteria.and("logUserInfo.userType").is(params.get("userType").toString()); criteria.and("logUserInfo.userType").is(params.get("userType").toString());
} }
if(params.get("beginTime")!=null){ if(params.get("beginTime")!=null){
criteria.and("createTime").gte((Date) params.get("beginTime")); List<String> days = getDayList((Date) params.get("beginTime"));
if(CollectionUtils.isNotEmpty(days)){
criteria.and("yearMonthDay").in(days);
}
} }
if(params.get("endTime")!=null){ if(params.get("endTime")!=null){
criteria.lte((Date) params.get("endTime")); criteria.lte((Date) params.get("endTime"));
...@@ -88,11 +91,29 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St ...@@ -88,11 +91,29 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St
} }
if(beginTime!=null){ if(beginTime!=null){
criteria.and("createTime").gte(beginTime); List<String> days = getDayList(beginTime);
if(CollectionUtils.isNotEmpty(days)){
criteria.and("yearMonthDay").in(days);
}
} }
return super.distinct(key,new Query(criteria),String.class); return super.distinct(key,new Query(criteria),String.class);
} }
private List<String> getDayList(Date beginTime){
Calendar nextDay = Calendar.getInstance();
nextDay.add(Calendar.DATE, 1);
Calendar calendar = Calendar.getInstance();
calendar.setTime(beginTime);
Set<String> days = new HashSet<>();
while (calendar.before(nextDay)){
days.add(DateUtils.dateToString(calendar.getTime(), "yyyy-MM-dd"));
}
return new ArrayList<>(days);
}
public long count(Map<String, Object> params){ public long count(Map<String, Object> params){
Criteria criteria = new Criteria(); Criteria criteria = new Criteria();
if (null != params && params.size() > 0){ if (null != params && params.size() > 0){
...@@ -112,7 +133,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St ...@@ -112,7 +133,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St
}); });
} }
if(beginTime!=null){ if(beginTime!=null){
criteria.and("createTime").gte(beginTime); List<String> days = getDayList(beginTime);
if(CollectionUtils.isNotEmpty(days)){
criteria.and("yearMonthDay").in(days);
}
} }
Query query = Query.query(criteria); Query query = Query.query(criteria);
return count(query); return count(query);
...@@ -130,7 +154,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St ...@@ -130,7 +154,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St
} }
if(beginTime!=null){ if(beginTime!=null){
criteria.and("createTime").gte(beginTime); List<String> days = getDayList(beginTime);
if(CollectionUtils.isNotEmpty(days)){
criteria.and("yearMonthDay").in(days);
}
} }
Query query = Query.query(criteria); Query query = Query.query(criteria);
return count(query); return count(query);
...@@ -163,7 +190,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St ...@@ -163,7 +190,10 @@ public class AuthLogDao extends StaticCacheDimensionDocumentMongoDao<AuthLog, St
}); });
} }
if(beginTime!=null){ if(beginTime!=null){
criteria.and("createTime").gte(beginTime); List<String> days = getDayList(beginTime);
if(CollectionUtils.isNotEmpty(days)){
criteria.and("yearMonthDay").in(days);
}
} }
List<Bson> aggregateList = new ArrayList<>(); List<Bson> aggregateList = new ArrayList<>();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment