视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Mysql中的count()与sum()区别详细介绍
2020-11-09 21:11:03 责编:小采
文档


首先创建个表说明问题
代码如下:
CREATE TABLE `result` (
`name` varchar(20) default NULL,
`subject` varchar(20) default NULL,
`score` tinyint(4) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8

插入一些数据,
代码如下:
insert into result values
('张三','数学',90),
('张三','语文',50),
('张三','地理',40),
('李四','语文',55),
('李四','政治',45),
('王五','政治',30),
('赵六','语文',100),
('赵六','数学',99),
('赵六','品德',98);

要求:查询出2门及2门以上不及格者的平均成绩。
经常会用两种查询语句有两种:
代码如下:
select name,sum(score < 60) ,avg(score) from result group by name having sum(score<60) >=2;

代码如下:
select name ,count((score<60)!=0) as a,avg(score) from result group by name having a >=2;

两种查询的结果肯定是不一样的,肯定是第一种正确的,原因是为什么,这时你就要想了,count()函数的意义和sum函数的意义
count()函数里面的参数是列名的的时候,那么会计算有值项的次数。
Sum()函数里面的参数是列名的时候,是计算列名的值的相加,而不是有值项的总数。
对count()行数还要注意:它会计算总行数。不管你是否有值都会列入计算范围。另外一点:mysqlisam引擎很容易获得总行数的统计。查询速度变得更快
归纳:实际编程中统计总行数是经常用到的。此时使用count(*)多处可见。我很少看到有人使用列名作为参数:count(a)的情况。即使是这样使用,可能其初衷也是想统计行数。只是不知道!这样所造成的细微差异而错误使用了"列名"的形式。

您可能感兴趣的文章:

  • 深入分析Mysql中limit的用法
  • MySql中取前几行数据使用limit来完成
  • 详解MySQL的limit用法和分页查询语句的性能分析
  • Mysql中limit的用法方法详解与注意事项
  • mysql delete limit 使用方法详解
  • mysql优化limit查询语句的5个方法
  • MYSQL中有关SUM字段按条件统计使用IF函数(case)问题
  • mysql中sum float类型使用小数点的方法
  • MySQL中的SUM函数使用教程
  • mysql踩坑之limit与sum函数混合使用问题详解
  • 下载本文
    显示全文
    专题