查询一个表里 每个部门总人数、以及男生所占的百分比 该怎么写sql语句
2017-01-12
展开全部
select 性别字段 ,count(*) 人数,
cast( convert (decimal(18,2),100*cast(count(*) as float)/cast((select count(*) from 表) as float) ) as varchar)+'%'
from 表 group by 性别字段
--试试,应该可以用
cast( convert (decimal(18,2),100*cast(count(*) as float)/cast((select count(*) from 表) as float) ) as varchar)+'%'
from 表 group by 性别字段
--试试,应该可以用
追问
每个部门的总人数也要显示
追答
with A AS(
select 性别 ,所在部门,count(*) 人数,
cast( convert (decimal(18,2),100*cast(count(*) as float)/cast((select count(*) from 表) as float) ) as varchar)+'%' AS 百分比
from 表 group by 所在部门,性别),
B AS(select 所在部门,COUNT(*) 部门人数 from 表 group by 所在部门)
SELECT * FROM A,B where A.所在部门 = B.所在部门
--试试,应该可以用
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询