单个select语句实现MySQL查询统计次数

单个select语句实现MySQL查询统计次数的方法用处在哪里呢?用处太多了,比如一个成绩单,你要查询及格得人数与不及格的人数,怎么一次查询出来?

MySQL查询统计次数简单的语句肯定是这样了:

 
 
 
  1. select a.name,count_neg,count_plus from   
  2. (select count(id) as count_plus,name from score2 where score >=60 group by name) a,  
  3. (select count(id) as count_neg,name from score2 where score <=60 group by name) b   
  4. where a.name=b.name  
  5.  

即必须至少用2个语句。

今天刚好碰到发现mysql支持if,那就创造性的用if来实现吧:

 
 
 
  1. select name, sum(if(score>=60,1,0)),sum(if(score<60,1,0)) from score2 group by name  
  2.  

单个select语句实现MySQL查询统计次数的方法简单吧。

原理就是大于60,就赋值为1,那么sum就是计数了。

【编辑推荐】

MySQL查询结果按某值排序

MySQL查询中的非空问题

教您如何调整MySQL查询缓冲

MySQL查询优化器的工作原理

深度解析MySQL查询缓存机制


名称栏目:单个select语句实现MySQL查询统计次数
文章出自:http://www.hxwzsj.com/article/dpjeehi.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 网站制作 成都网站制作 定制网站制作 四川成都网站建设 网站设计 成都网站设计 手机网站建设 外贸营销网站建设 温江网站设计 成都网站建设 泸州网站建设 攀枝花网站设计 成都网站建设公司 专业网站设计 网站建设方案 成都网站设计 阿坝网站设计 重庆网站建设 外贸网站设计方案 成都定制网站建设 盐亭网站设计 古蔺网站建设