считать строки в объединенной таблице, но отображать 0, если строк не существует - mysql - PullRequest
1 голос
/ 14 января 2011

Таблица заголовка ответа является объединенной таблицей, которая считается для отображения ответов на конкретный опрос.Если строк нет, следовательно, нет ответов, я хочу, чтобы счетчик отображал 0. Но вместо этого он пропускает строку, поскольку в таблице не найден параметр соединения (survey_id).

SELECT DATE_FORMAT(launched_date,'<nobr>%e-%b-%Y %H:%i:%s</nobr>'),
survey.NAME,
survey.iris_type,
survey.launched_by,
COUNT(response_header_2010.survey_id) AS response_count,
survey.survey_id,
survey.NAME 

FROM survey, response_header_2010

WHERE survey.STATUS='Live' 
AND survey.iris_type!='Recipient List'
AND response_header_2010.survey_id = survey.survey_id
AND client_id = '98'

GROUP BY  survey.survey_id, survey.NAME

ORDER BY response_count

1 Ответ

2 голосов
/ 14 января 2011

Вы хотите использовать левое соединение вместо внутреннего соединения, которое у вас есть в настоящее время.

SELECT DATE_FORMAT(launched_date,'<nobr>%e-%b-%Y %H:%i:%s</nobr>'),
survey.NAME,
survey.iris_type,
survey.launched_by,
COUNT(response_header_2010.survey_id) AS response_count,
survey.survey_id,
survey.NAME 

FROM survey
LEFT JOIN response_header_2010
    ON survey.survey_id = response_header_2010.survey_id
WHERE survey.STATUS='Live' 
AND survey.iris_type!='Recipient List'
AND client_id = '98'

GROUP BY  survey.survey_id, survey.NAME

ORDER BY response_count
...