私が作った求人サイトのレポーティングシステムを書いています。これまでのところ、以下の関数を取得して、日、週、月、または年でグループ化された特定の期間の合計ジョブを引き出すことができました
私がやりたいのは、同じ期間の求人応募総数を引き出すことです。求人応募は、job_application という別のテーブルに格納され、job_application_id、job_id、および date_added フィールドが含まれています。
同じクエリでそのデータを引き出す方法はありますか? SQL は私の脳を揚げ始めているので、どんな助けも大歓迎です!
public function getJobReport($data = array()) {
$sql = "SELECT MIN(tmp.date_added) AS date_start, MAX(tmp.date_added) AS date_end, COUNT(tmp.job_id) AS `jobs` FROM (SELECT j.job_id, j.date_added FROM `" . DB_PREFIX . "job` j WHERE 1";
if (isset($data['date_start']) && $data['date_start']) {
$sql .= " AND DATE(j.date_added) >= '" . $this->db->escape($data['date_start']) . "'";
}
if (isset($data['date_end']) && $data['date_end']) {
$sql .= " AND DATE(j.date_added) <= '" . $this->db->escape($data['date_end']) . "'";
}
$sql .= " GROUP BY j.job_id) tmp";
if (isset($data['group'])) {
$group = $data['group'];
} else {
$group = 'week';
}
switch($group) {
case 'day';
$sql .= " GROUP BY DAY(tmp.date_added)";
break;
default:
case 'week':
$sql .= " GROUP BY WEEK(tmp.date_added)";
break;
case 'month':
$sql .= " GROUP BY MONTH(tmp.date_added)";
break;
case 'year':
$sql .= " GROUP BY YEAR(tmp.date_added)";
break;
}
if (isset($data['start']) || isset($data['limit'])) {
if ($data['start'] < 0) {
$data['start'] = 0;
}
if ($data['limit'] < 1) {
$data['limit'] = 20;
}
$sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
}
$query = $this->db->query($sql);
return $query->rows;
}