Мне нужно сделать запрос, чтобы получить результат конкретного экзамена для каждого учащегося, и я также хочу отобразить NULL для ученика, который не ввел его баллы ....
Вот мои четыре стола
Student
стол
Scores
таблица
Student
student_subject




Ссылка на мою таблицу
Мой запрос работает, но у меня нет значения NULL для учащегося, у которого нет ввода его оценки
SELECT
scores.result, students.id, exam.name, exam.id
FROM
scores
LEFT JOIN
students ON scores.user_id = students.user_id
LEFT JOIN
exam ON exam.id = scores.exam_id
LEFT JOIN
students_subjects as ss ON ss.user_id = students.id
LEFT JOIN
students_subjects ON students_subjects.group_id = exam.group_id
WHERE
exam.id = 32
GROUP BY
scores.id
* * Выход тысяча сорок-девять

Как я могу получить нулевое значение для каждого студента, у которого нет оценки для конкретного экзамена (exam.id = 32)?
Отредактировано для @ sceaj
Я получил это по вашему запросу (я изменяю WHERE exam.id = 34 для WHERE exam.id = 36 для лучшего тестирования)
SELECT scores.result,students.id,exam.name, exam.id
FROM exam
INNER JOIN students_subjects ON students_subjects.group_id = exam.group_id
INNER JOIN students ON students_subjects.user_id = students.user_id
LEFT OUTER JOIN scores ON scores.user_id = students.user_id
WHERE exam.id = 36
