我正在为我制作的招聘网站编写报告系统。到目前为止,我已经设法获得下面的函数来完成给定时间段内的总工作量,以天、几周、几个月或几年为单位
我想做的是浏览同一时期的所有工作申请。工作申请存储在另一个名为 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;
}