Calculating percentage within a group

后端 未结 2 822
离开以前
离开以前 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:48

    May be too late, but for upcoming searchers, possible solution could be:

    select sex, employed, COUNT(*) / CAST( SUM(count(*)) over (partition by sex) as float)
      from my_table
     group by sex, employed
    

    By IO Statistics this seems to be most effective solution - may be dependant on number of rows to be queried - tested on numbers above ...

    The same attitude could be used for getting male / female percentage:

    select sex, COUNT(*) / CAST( SUM(count(*)) over () as float)
      from my_table
     group by sex
    

    Regards, Jan

提交回复
热议问题