Я пытаюсь получить данные о некоторых студентах, которые все еще активны. Даже если у меня есть данные от неактивных студентов в одной таблице.
Это StudentAttendance
Это StudentClass
Это красноречивый запрос, с которым я пришел:
StudentAttendance::
select('student_classes.active', 'student_attendances.student_id', 'student_attendances.classroom_id', 'classrooms.classroom', 'attendance_rules.option')
->join('classrooms', 'classrooms.id', '=', 'student_attendances.classroom_id')
->join('attendance_rules','attendance_rules.id', '=', 'student_attendances.attendance_id')
->join('student_classes', 'student_attendances.student_id', '=', 'student_classes.student_id')
->where('attendance_date', date("Y-m-d"))
->orderBy('classrooms.classroom', 'ASC')
->get();
SQL:
select `student_classes`.`active`, `student_attendances`.`student_id`, `student_attendances`.`classroom_id`, `classrooms`.`classroom`, `attendance_rules`.`option`
from `student_attendances`
inner join `classrooms` on `classrooms`.`id` = `student_attendances`.`classroom_id`
inner join `attendance_rules` on `attendance_rules`.`id` = `student_attendances`.`attendance_id`
inner join `student_classes` on `student_attendances`.`student_id` = `student_classes`.`student_id`
where `attendance_date` = '2020-02-11'
order by `classrooms`.`classroom` asc
Теперь мой Eloquent запрос приводит к следующему:
Как вы можете видеть, student_id 22 с classroom_id 2 неактивен, но он появляется быть неактивным один раз, а остальные активными. Если я удалю объединение student_classes, я не получу все повторяющиеся результаты.
Цель состоит в том, чтобы отобразить все сегодняшние посещения, где студент активен (active = 1), в StudentClass, даже если я запрашиваю в Студенческое присутствие.