0

私が作った求人サイトのレポーティングシステムを書いています。これまでのところ、以下の関数を取得して、日、週、月、または年でグループ化された特定の期間の合計ジョブを引き出すことができました

私がやりたいのは、同じ期間の求人応募総数を引き出すことです。求人応募は、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;        
}
4

1 に答える 1

1

ここでサブクエリが必要な理由がすぐにはわかりません...このクエリは左結合を使用し、入力の開始日と終了日を列として選択し、それによって GROUP を選択します (したがって、結果行は 1 つだけになります)。これを読みやすくするために、識別子の詳細を少し省略しました。

...
$date_resolution_function = "DAY"; // set via a switch similar to yours
...
SELECT 
  $date_resolution_function(apps.date_added), 
  count(jobs.id) as numb_jobs, 
  count(apps.id) as num_apps
FROM 
  jobs JOIN job_application as apps ON jobs.id = apps.job_id
WHERE apps.date_added BETWEEN $start_date AND $end_date
GROUP BY $date_resolution_function(apps.date_added)

編集:この手法では、開始日と終了日を設定する必要があることに注意してください...しかし、とにかく合理的なデフォルトを定義することを強くお勧めします。デフォルトを広くしたい場合は、エポックと+100年後などを使用します...しかし、おそらく「この四半期」のようなものがクライアントにより適しています。

編集 2 (日付解決の追加): この種のクエリでは、ジョブまたはアプリケーションのいずれかでのみ正確な日付選択を取得でき、もう一方は「すべて」になることを認識することが重要です。私はより賢明だと思うものを選び、応募日に選択し、いつ投稿されたかに関係なくすべての仕事を含めました(指定された期間中に応募があった場合)。逆の方法 (期間中に投稿された求人のみを表示) が必要な場合は、日付関数に渡される列を変更し、JOIN を LEFT 結合にすることができます。仕事は、仕事が掲載された日/週だけでなく、全期間になります。

于 2012-07-05T16:29:23.933 に答える