首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DISTINCT的问题!

DISTINCT的问题!
EN

Stack Overflow用户
提问于 2009-10-05 16:58:48
回答 5查看 403关注 0票数 2

下面是我的问题:

代码语言:javascript
复制
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列。问题出在哪里?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-10-05 17:02:42

实际上,DISTINCT不会将自身限制为1列,基本上当您说:

选择不同的a,b

你的意思是,“给我a和b的不同值”..就像多列唯一索引一样

票数 9
EN

Stack Overflow用户

发布于 2009-10-05 17:03:42

distinct将确保select子句中的所有值都是唯一的,而不仅仅是user_id。如果您希望将结果限制为单个user_ids,则应按user_id进行分组。

也许你想要的是:

代码语言:javascript
复制
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;
票数 6
EN

Stack Overflow用户

发布于 2009-10-05 17:04:51

DISTINCT工作在行级别,而不仅仅是列级别

如果你只想要一个列的DISTiNCT,那么你必须聚合返回的其余列(MIN,MAX,SUM,AVG等)

代码语言:javascript
复制
SELECT DISTINCT (Name), Min (ID)
From MyTable
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1521219

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档