Calculating percentage within a group

后端 未结 2 804
离开以前
离开以前 2020-12-24 13:03

given a table that for the following commands:

select sex, count(*) from my_table group by sex;
select sex, employed, count(*) from my_table group by sex, em         


        
2条回答
  •  醉梦人生
    2020-12-24 13:27

    You can do it with a sub-select and a join:

    SELECT t1.sex, employed, count(*) AS `count`, count(*) / t2.total AS percent
      FROM my_table AS t1
      JOIN (
        SELECT sex, count(*) AS total 
          FROM my_table
          GROUP BY sex
      ) AS t2
      ON t1.sex = t2.sex
      GROUP BY t1.sex, employed;
    

    I can't think of other approaches off the top of my head.

提交回复
热议问题