select('date as labels') ->selectSum('hits', 'values') ->where([ 'episode_id' => $episodeId, 'podcast_id' => $podcastId, 'age <' => 60, ]) ->groupBy('labels') ->orderBy('labels', 'ASC') ->findAll(); cache() ->save("{$podcastId}_{$episodeId}_analytics_podcast_by_episode_by_day", $found, 600); } return $found; } /** * @return AnalyticsPodcastsByEpisode[] */ public function getDataByMonth(int $podcastId, int $episodeId = null): array { if ( ! ($found = cache("{$podcastId}_{$episodeId}_analytics_podcast_by_episode_by_month")) ) { $found = $this->select('DATE_FORMAT(date,"%Y-%m-01") as labels') ->selectSum('hits', 'values') ->where([ 'episode_id' => $episodeId, 'podcast_id' => $podcastId, ]) ->groupBy('labels') ->orderBy('labels', 'ASC') ->findAll(); cache() ->save("{$podcastId}_{$episodeId}_analytics_podcast_by_episode_by_month", $found, 600); } return $found; } }