use of org.hisp.dhis.datastatistics.DataStatisticsEventType in project dhis2-core by dhis2.
the class HibernateDataStatisticsEventStore method getFavoritesData.
@Override
public List<FavoriteStatistics> getFavoritesData(DataStatisticsEventType eventType, int pageSize, SortOrder sortOrder, String username) {
Assert.notNull(eventType, "Data statistics event type cannot be null");
Assert.notNull(sortOrder, "Sort order cannot be null");
String sql = "select c.uid, views, c.name, c.created from ( " + "select favoriteuid as uid, count(favoriteuid) as views " + "from datastatisticsevent ";
if (username != null) {
sql += "where username = ? ";
}
sql += "group by uid) as events " + "inner join " + eventType.getTable() + " c on c.uid = events.uid " + "order by events.views " + sortOrder.getValue() + " " + "limit ?;";
PreparedStatementSetter pss = (ps) -> {
int i = 1;
if (username != null) {
ps.setString(i++, username);
}
ps.setInt(i++, pageSize);
};
return jdbcTemplate.query(sql, pss, (rs, i) -> {
FavoriteStatistics stats = new FavoriteStatistics();
stats.setPosition(i + 1);
stats.setId(rs.getString("uid"));
stats.setName(rs.getString("name"));
stats.setCreated(rs.getDate("created"));
stats.setViews(rs.getInt("views"));
return stats;
});
}
use of org.hisp.dhis.datastatistics.DataStatisticsEventType in project dhis2-core by dhis2.
the class HibernateDataStatisticsEventStore method getDataStatisticsEventCount.
@Override
public Map<DataStatisticsEventType, Double> getDataStatisticsEventCount(Date startDate, Date endDate) {
Map<DataStatisticsEventType, Double> eventTypeCountMap = new HashMap<>();
final String sql = "select eventtype as eventtype, count(eventtype) as numberofviews " + "from datastatisticsevent " + "where timestamp between ? and ? " + "group by eventtype;";
PreparedStatementSetter pss = (ps) -> {
int i = 1;
ps.setDate(i++, asSqlDate(startDate));
ps.setDate(i++, asSqlDate(endDate));
};
jdbcTemplate.query(sql, pss, (rs, i) -> {
eventTypeCountMap.put(DataStatisticsEventType.valueOf(rs.getString("eventtype")), rs.getDouble("numberofviews"));
return eventTypeCountMap;
});
final String totalSql = "select count(eventtype) as total " + "from datastatisticsevent " + "where timestamp between ? and ?;";
jdbcTemplate.query(totalSql, pss, (resultSet, i) -> {
return eventTypeCountMap.put(DataStatisticsEventType.TOTAL_VIEW, resultSet.getDouble("total"));
});
return eventTypeCountMap;
}
Aggregations