单个select语句实现MySQL查询统计次数的方法用处在哪里呢?用处太多了,比如一个成绩单,你要查询及格得人数与不及格的人数,怎么一次查询出来?
MySQL查询统计次数简单的语句肯定是这样了:
- select a.name,count_neg,count_plus from
- (select count(id) as count_plus,name from score2 where score >=60 group by name) a,
- (select count(id) as count_neg,name from score2 where score <=60 group by name) b
- where a.name=b.name
即必须至少用2个语句。
今天刚好碰到发现mysql支持if,那就创造性的用if来实现吧:
- select name, sum(if(score>=60,1,0)),sum(if(score<60,1,0)) from score2 group by name
单个select语句实现MySQL查询统计次数的方法简单吧。
原理就是大于60,就赋值为1,那么sum就是计数了。
【编辑推荐】
MySQL查询结果按某值排序
MySQL查询中的非空问题
教您如何调整MySQL查询缓冲
MySQL查询优化器的工作原理
深度解析MySQL查询缓存机制
本文标题:单个select语句实现MySQL查询统计次数
当前路径:http://www.mswzjz.cn/qtweb/news28/342928.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能