У меня есть две таблицы, одна для новостей, а другая для комментариев, и я хочу получить количество комментариев, статус которых был установлен как одобренный.
SELECT
ccc_news . *,
count(if(ccc_news_comments.id = 'approved', ccc_news_comments.id, 0)) AS comments
FROM
ccc_news
LEFT JOIN
ccc_news_comments
ON ccc_news_comments.news_id = ccc_news.news_id
WHERE
`ccc_news`.`category` = 'news_layer2'
AND `ccc_news`.`status` = 'Active'
GROUP BY
ccc_news.news_id
ORDER BY
ccc_news.set_order ASC
LIMIT 20
Но проблема с этим запросом заключается в том, что минимальное значение, которое выбирается для столбца комментариев, равно 1, независимо от того, существует ли какой-либо комментарий, соответствующий этой новости, или нет.
Любая помощь будет очень заметна.
mysql
join
if-statement
count
user1163513
источник
источник
Ответы:
Использовать
sum()
вместоcount()
Попробуйте ниже:
источник
null
когдаCOUNT
(без условий) вернется0
. КогдаCOUNT
бы я вернулся ничего , кроме 0, ноSUM
делает возврат 0, ваш трюк возвращается0
.num_relevant_parts
естьSUM
с условиями,num_total_parts
являетсяCOUNT(parts.id)
(извините за двойной комментарий, было слишком поздно , чтобы редактировать)Еще лучше (или короче):
Это работает, поскольку логический тип в MySQL представлен как
INT
0
и1
, как и в C. (хотя может не переноситься в системы БД).Что касается,
COALESCE()
как упоминалось в других ответах, многие языковые API автоматически конвертируютсяNULL
в''
при извлечении значения. Например, сmysqli
интерфейсом PHP было бы безопасно выполнять ваш запрос безCOALESCE()
.источник
Это должно работать:
count()
только проверьте, существует ли значение или нет. 0 эквивалентно существующему значению, поэтому он учитывает еще одно, в то время как NULL похож на несуществующее значение, поэтому не учитывается.источник
count
более интуитивным, чемsum
в этом случае.Замените эту строку:
С этим:
источник
COALESCE
возвращает ли сумму? Любая ссылка в документе MySQL?