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

2023年 4月 23日 26.8k 0

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

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

单个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查询统计函数中的count

今天我遇到一个题目:统计所有女生成绩大于90以上有总数我刚开始就这样写:$sql = "select 女生成绩 from use where 成绩 > 90“;$result = mysql_query($sql);$row = mysql_num_rows($result);echo "总数为:$row";可是100条还行吧,如果是10000条那是不是要很慢啊!!后来一个朋友给我说用count函数,这我才想起来。把上面的sql语句改为:$sql = "select count(*),女生成绩 from use group by 女生成绩 having 女生成绩 > 90";这样查询语句就快多了 

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论