请教一个 mysql 查询问题!

2019-09-09 12:43:20 +08:00
 itIsUnbelievable

弱弱地问一个基础的 mysql 问题。我写的 sql 语句只查询出了根据日期分组的单日男性女性在表中分别有多少条记录。而不是男性女性分别有多少人。(因为其中的一些记录 ID 是重复的,也就是同一个人有多条不同的记录。)
我想要统计出每天男性女性分别有多少人?我要如何修改我的 sql 语句呢? 还是说我这样的表设计是有问题的呢?


hangzhou 表

结果

我想要的结果是
2019-4-25 2 2
2019-4-29 2 2
1756 次点击
所在节点    问与答
18 条回复
xingyue
2019-09-09 12:57:21 +08:00
distinct
itIsUnbelievable
2019-09-09 13:31:47 +08:00
@xingyue 我试过了,没有用
mringg
2019-09-09 13:33:18 +08:00
count 改为 sum
justfindu
2019-09-09 13:37:35 +08:00
SELECT
SUM( IF ( sex = male, 1, 0 ) ) AS male_count,
SUM( IF ( sex = female, 1, 0 ) ) AS female
FROM
`TABLE`
GROUP BY
date
itIsUnbelievable
2019-09-09 13:49:17 +08:00
@justfindu 你这个的结果和我那个是一样的。还是没有对 uid 进行去重
itIsUnbelievable
2019-09-09 13:55:43 +08:00
@mringg 还是一样的结果,因为 4-25 日那天是有 2 个用户 id 重复的,所以统计人数的时候要去掉重复的,所以我就找不到方向了。distinct 也没有用,很难受(⊙﹏⊙)
cnoder
2019-09-09 13:57:49 +08:00
select sex,count(1) as gender_num from hangzhou where id in (select id from hangzhou group by uid,date) GROUP BY sex
如果不报 onlyfullgroupby 的错误应该可以,另外性别应该用 gender
polymerdg
2019-09-09 14:08:24 +08:00
group by date,uid
noahsophie
2019-09-09 14:09:53 +08:00
group by sex,date
noahsophie
2019-09-09 14:10:32 +08:00
看错了,8 楼正解
itIsUnbelievable
2019-09-09 14:14:30 +08:00
@cnoder <img src="http://tva1.sinaimg.cn/large/007X8olVly1g6t8ijkmptj30pm05k0sp.jpg">

<br>
你的查询结果是这个,这个不是只统计出了表中男女性别的记录条数,没有去重的效果,而且日期也不是按照我结果的样式,这个问题也太难了吧,感觉我 mysql 好菜呀
itIsUnbelievable
2019-09-09 14:28:07 +08:00
@polymerdg
<img src="http://tva1.sinaimg.cn/large/007X8olVly1g6t8zeedkqj30kh09iq35.jpg">
这个我之前也试过,不过结果不对。
itIsUnbelievable
2019-09-09 14:48:34 +08:00
偷偷地顶一下....
justfindu
2019-09-09 15:14:24 +08:00
@itIsUnbelievable group by 再加上 uid 就行了
x66
2019-09-09 15:18:24 +08:00
@itIsUnbelievable #13
SELECT t.date,count(case when t.sex ='male' then 1 end ) male,count(case when t.sex ='female' then 1 end ) female
from (
SELECT date,uid,sex from test1 GROUP BY date,uid,sex
) t GROUP BY t.date
itIsUnbelievable
2019-09-09 15:31:10 +08:00
@x66 老哥秀啊,这么多回答就你这个靠谱,谢谢老哥
haozxuan001
2019-09-09 17:26:02 +08:00
都是些什么神仙呀,
你把你的 THEN 1 改成 THEN distinct (id)岂不是改动最小的?
haozxuan001
2019-09-09 17:26:27 +08:00
手抖了,distinct(uid)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/599262

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX