A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© dqzg12300 中级黑马   /  2012-10-26 16:54  /  2222 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

姓名  年龄   工号   薪水
jin        20      001      1500
wang    21      002      1800
li          25      003       1800
kang     30      004       1500
查询各阶段工资的人数
比如1500有2个人拿 1800也是2个人拿
不要用where 工资=1500 然后又where 工资=1800.要一次性查出来。
列出来的表要是这样
工资      人数
1500           2
1800          2
要怎么做到啊?

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

3 个回复

倒序浏览
用count和group by就可以做到了。
数据表如图:
sql:select count(姓名),薪水 from Table_1
group by 薪水。
查询结果如图:

即用group by根据薪水分组(出现1500和1800两组),再用count通过姓名不同计算每组薪水总共含有的人数。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
····难怪了我之前select count(姓名),薪水 from Table_1这样写的。但是老是提示我用group by。我忘记这个是分组的了。以为是排序的。晕·
回复 使用道具 举报
dqzg12300 发表于 2012-10-26 17:15
····难怪了我之前select count(姓名),薪水 from Table_1这样写的。但是老是提示我用group by。我忘记这 ...

order by是排序,group by 是分组,我初学sql的时候,也弄错了,那时候对英文不熟
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马