加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

从mysql表中的同一列获取计数?

发布时间:2020-12-11 23:30:58 所属栏目:MySql教程 来源:网络整理
导读:我想为不同的值计算相同的字段,例如: user{user_id,gender} 性别可以有明显的男性或女性:) 我想得到所有男性和女性的数量,即 COUNT(male) COUNT(female) 4 16 但我很困惑,因为他们来自同一性别coloumn谢谢最佳答案试试这个行的结果: SELECT gender,COUNT(U

我想为不同的值计算相同的字段,例如:

user{user_id,gender}

性别可以有明显的男性或女性:)

我想得到所有男性和女性的数量,即

COUNT(male)   COUNT(female)  
   4               16

但我很困惑,因为他们来自同一性别coloumn谢谢 最佳答案 试试这个行的结果:

SELECT gender,COUNT(User_id) AS count
FROM User
GROUP BY gender;

输出:

| gender | count |
|--------|-------|
|      F |     4 |
|      M |     2 |

尝试使用总计的行方式结果:

SELECT  (IFNull(gender,'Total')) AS gender,COUNT(User_id) AS Count
FROM User
GROUP BY gender
WITH rollup;

输出:

| gender | Count |
|--------|-------|
|      F |     4 |
|      M |     2 |
|  Total |     6 |

尝试以列方式结果:

SELECT
  COUNT(CASE WHEN gender = 'M' THEN User_id END) AS males,COUNT(CASE WHEN gender = 'F' THEN User_id END) AS females,COUNT(*) AS Total
FROM User;

输出:

| males | females | Total |
|-------|---------|-------|
|     2 |       4 |     6 |

See this SQLFiddle

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读