Итак, я хочу получить все позиции SSC и получить количество позиций, которые еще не заняты.Однако я как-то застрял в предложении where.
Вот мои структуры таблиц:
data:image/s3,"s3://crabby-images/1f287/1f28765ffeef854d7842792e97688544c594572c" alt="Position"
data:image/s3,"s3://crabby-images/ae119/ae119cfba2cdc470df70f153e0dd27d45385735c" alt="SSC"
data:image/s3,"s3://crabby-images/2bfcb/2bfcb87c487b2e515dce06b162cb897edc26a977" alt="Student"
data:image/s3,"s3://crabby-images/77c59/77c599669a15970d09778440bfe498ad30f8694d" alt="Account"
А вот и мой запрос
SELECT p.position_id, a.account_id
FROM positions p
LEFT JOIN ssc s ON s.position_id = p.position_id AND s.removed = 0
LEFT JOIN students stud ON stud.students_id = s.students_id
LEFT JOIN accounts a ON a.account_id = stud.account_id
WHERE p.user_level_id = 6
AND p.removed = 0
Фактический результат таков:
data:image/s3,"s3://crabby-images/66ece/66ece6a04a3a030098b453423e5d67d74db5ad90" alt="Result"
Ожидаемый результат для отображения только тех полей, которые имеют значение NULL в account_id.Однако, если я включу AND a.account_id = NULL
в запрос, результат будет пустым.И если я когда-нибудь изменю запрос на:
SELECT p.position_id, a.account_id
FROM positions p
LEFT JOIN ssc s ON s.position_id = p.position_id AND s.removed = 0
LEFT JOIN students stud ON stud.students_id = s.students_id
LEFT JOIN accounts a ON a.account_id = stud.account_id AND a.account_id = NULL
WHERE p.user_level_id = 6
AND p.removed = 0
, тогда весь идентификатор учетной записи станет NULL