下面是我的问题:
SELECT
DISTINCT `c`.`user_id`,
`c`.`created_at`,
`c`.`body`,
(SELECT COUNT(*) FROM profiles_comments c2 WHERE c2.user_id = c.user_id AND c2.profile_id = 1) AS `comments_count`,
`u`.`username`,
`u`.`avatar_path`
FROM `profiles_comments` AS `c` INNER JOIN `users` AS `u` ON u.id = c.user_id
WHERE (c.profile_id = 1) ORDER BY `u`.`id` DESC;它起作用了。不过,问题出在这个独特的词上。据我所知,它应该为每个c.user_id只选择一行。
但我得到的结果甚至是4-5行具有相同的c.user_id列。问题出在哪里?
发布于 2009-10-05 17:02:42
实际上,DISTINCT不会将自身限制为1列,基本上当您说:
选择不同的a,b
你的意思是,“给我a和b的不同值”..就像多列唯一索引一样
发布于 2009-10-05 17:03:42
distinct将确保select子句中的所有值都是唯一的,而不仅仅是user_id。如果您希望将结果限制为单个user_ids,则应按user_id进行分组。
也许你想要的是:
SELECT
`c`.`user_id`,
`u`.`username`,
`u`.`avatar_path`,
(SELECT COUNT(*) FROM profiles_comments c2 WHERE c2.user_id = c.user_id AND c2.profile_id = 1) AS `comments_count`
FROM `profiles_comments` AS `c` INNER JOIN `users` AS `u` ON u.id = c.user_id
WHERE (c.profile_id = 1)
GROUP BY `c`.`user_id`,
`u`.`username`,
`u`.`avatar_path`
ORDER BY `u`.`id` DESC;发布于 2009-10-05 17:04:51
DISTINCT工作在行级别,而不仅仅是列级别
如果你只想要一个列的DISTiNCT,那么你必须聚合返回的其余列(MIN,MAX,SUM,AVG等)
SELECT DISTINCT (Name), Min (ID)
From MyTablehttps://stackoverflow.com/questions/1521219
复制相似问题