Я пытаюсь создать запрос SQL, который зависит от параметров, отправленных из формы.В рамках этого я хочу попытаться поделиться эффектами основного оператора предложения WHERE с предложением WHERE для подзапроса.
Например, используя pass_count, я хочу подсчитать количество строк, где total_passfail = "Pass",Однако это число может измениться из-за использования функции основных запросов WHERE (в основной функции WHERE у меня есть 8 возможных вариантов, таких как диапазон дат, пользователь, команда, отдел, которые соответственно формируют общие данные).
Isесть какой-то способ, чтобы общее предложение WHERE влияло на подзапрос, а не добавление еще 8 WHERE к каждому подзапросу.По сути, я просто хочу, чтобы предложение WHERE подзапроса действовало поверх набора данных, который возвращает основной запрос.
Любая помощь будет принята с благодарностью.
$query = $this->db->join('users', 'users.staff_id = quality.staff_id')
->join('user_info', 'user_info.staff_id = users.staff_id')
->join('teams', 'teams.team_id = users.team_id')
->join('departments', 'teams.dept_id = departments.dept_id')
->join('quality_results', 'quality_results.qms_id = quality.qms_id')
->where('quality.published !=', "")
->where('quality.published !=', "0000-00-00 00:00:00")
->select('users.staff_id, user_info.name, user_info.surname, teams.team_name, departments.dept_name, COUNT(quality.qms_id) AS num_assessments, (SELECT (SUM(quality_results.total_result) / COUNT(quality_results.total_result))) AS average_result, (SELECT COUNT(quality_results.total_passfail) FROM quality_results WHERE quality_results.total_passfail = "Pass") AS pass_count');
if (strlen($query_array['task_date_from'])) {
$query->where('quality.task_datetime >=', $query_array['task_date_from']);
}
if (strlen($query_array['task_date_to'])) {
$query->where('quality.task_datetime <=', $query_array['task_date_to']);
}
(+ 4 MORE IF STATEMENTS HERE)
$result = $query->get('quality');
Я также устал от заменыподзапрос со следующим, но вместо этого появляется ошибка:
SUM(IF(quality_results.total_passfail = "Pass", 1,0)) AS pass_count
Вот мой необработанный код SQL:
SELECT `users`.`staff_id`, `user_info`.`name`, `user_info`.`surname`, `teams`.`team_name`, `departments`.`dept_name`, COUNT(quality.qms_id) AS num_assessments, (SELECT (AVG(quality_results.total_result))) AS average_result, (SELECT COUNT(quality_results.total_passfail) FROM quality_results WHERE quality_results.total_passfail = "Pass") AS pass_count FROM (`quality`) JOIN `users` ON `users`.`staff_id` = `quality`.`staff_id` JOIN `user_info` ON `user_info`.`staff_id` = `users`.`staff_id` JOIN `teams` ON `teams`.`team_id` = `users`.`team_id` JOIN `departments` ON `teams`.`dept_id` = `departments`.`dept_id` JOIN `quality_results` ON `quality_results`.`qms_id` = `quality`.`qms_id` JOIN `quality_tasks` ON `quality`.`task_id` = `quality_tasks`.`task_id` WHERE `quality`.`published` != '' AND `quality`.`published` != '0000-00-00 00:00:00' AND `quality`.`task_datetime` >= '2011-04-09' AND `quality`.`task_datetime` <= '2011-05-09' AND `teams`.`dept_id` = '1'