北京SEO

Mysql下count()和sum()区别

2019/10/10/17:33:57  阅读:1816  来源:谷歌SEO算法  标签: 黑猫SEO

在mysql中有两个函数count()与sum()函数,有很多朋友搞不清楚,从英文的角度我们可以分析出来count是统计个数,sum是求各并且只能是数值型.

要求:查询出2门及2门以上不及格者的平均成绩。

经常会用两种查询语句有两种:

select name,sum(score < 60) ,avg(score) from result group by name having sum(score<60) >=2;

再看,算你拥有动物的总数目与“在pet表中有多少行?”是同样的问题,因为每个宠物有一个记录。COUNT(*)函数计算行数,所以计算动物数目的查询应为:

  1. mysql>SELECTCOUNT(*)FROMpet;
  2. +----------+
  3. |COUNT(*)|
  4. +----------+
  5. |9|
  6. +----------+

在前面,你检索了拥有宠物的人的名字,如果你想要知道每个主人有多少宠物,你可以使用COUNT( )函数,代码如下:

  1. mysql>SELECTowner,COUNT(*)FROMpetGROUPBYowner;
  2. +--------+----------+
  3. |owner|COUNT(*)|
  4. +--------+----------+
  5. |Benny|2|
  6. |Diane|2|
  7. |Gwen|3|
  8. |Harold|2|
  9. +--------+----------+

注意,使用GROUP BY对每个owner的所有记录分组,没有它,你会得到错误消息,代码如下 :

mysql> SELECT owner, COUNT(*) FROM pet;

ERROR 1140 (42000): Mixing of GROUP columns (MIN(),MAX(),COUNT(),...)with no GROUP columns is illegal if there is no GROUP BY clause

COUNT( )和GROUP BY以各种方式分类你的数据,下列例子显示出进行动物普查操作的不同方式.

每种动物的数量,代码如下:

  1. mysql>SELECTspecies,COUNT(*)FROMpetGROUPBYspecies;
  2. +---------+----------+
  3. |species|COUNT(*)|
  4. +---------+----------+
  5. |bird|2|
  6. |cat|2|
  7. |dog|3|
  8. |hamster|1|
  9. |snake|1|
  10. +---------+----------+

每种性别的动物数量,代码如下:

  1. mysql>SELECTsex,COUNT(*)FROMpetGROUPBYsex;
  2. +------+----------+--phpfensi.com
  3. |sex|COUNT(*)|
  4. +------+----------+
  5. |NULL|1|
  6. |f|4|
  7. |m|4|
  8. +------+----------+

在这个输 出中,NULL表示“未知性别”.

按种类和性别组合的动物数量,代码如下:

  1. mysql>SELECTspecies,sex,COUNT(*)FROMpetGROUPBYspecies,sex;
  2. +---------+------+----------+
  3. |species|sex|COUNT(*)|
  4. +---------+------+----------+
  5. |bird|NULL|1|
  6. |bird|f|1|
  7. |cat|f|1|
  8. |cat|m|1|
  9. |dog|f|1|
  10. |dog|m|2|
  11. |hamster|f|1|
  12. |snake|m|1|
  13. +---------+------+----------+

若使用COUNT( ),你不必检索整个表,例如,前面的查询,当只对狗和猫进行时,应为:

  1. mysql>SELECTspecies,sex,COUNT(*)FROMpet
  2. ->WHEREspecies='dog'ORspecies='cat'
  3. ->GROUPBYspecies,sex;
  4. +---------+------+----------+
  5. |species|sex|COUNT(*)|
  6. +---------+------+----------+
  7. |cat|f|1|
  8. |cat|m|1|
  9. |dog|f|1|
  10. |dog|m|2|
  11. +---------+------+----------+

或如果你仅需要知道已知性别的按性别的动物数目,代码如下:

  1. mysql>SELECTspecies,sex,COUNT(*)FROMpet
  2. ->WHEREsexISNOTNULL
  3. ->GROUPBYspecies,sex;
  4. +---------+------+----------+
  5. |species|sex|COUNT(*)|
  6. +---------+------+----------+
  7. |bird|f|1|
  8. |cat|f|1|--phpfensi.com
  9. |cat|m|1|
  10. |dog|f|1|
  11. |dog|m|2|
  12. |hamster|f|1|
  13. |snake|m|1|
  14. +---------+------+----------+

mysql sum,代码如下:

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

广告内容

Mysql下count()和sum()区别 Mysql下count()和sum()区别 Mysql下count()和sum()区别

相关阅读

热门评论

sunshine技术博客 sunshine技术博客

sunshine技术博客

总篇数164

精选文章

RMAN中catalog和nocatalog区别介绍 小技巧:为Linux下的文件分配多个权限 zimbra8.5.1安装第三方签名ssl证书的步骤 解决mysql不能远程连接数据库方法 windows服务器mysql增量备份批处理数据库 mysql中slow query log慢日志查询分析 JavaScript跨域问题总结 Linux下负载均衡软件LVS配置(VS/DR)教程 mysql中权限参数说明 MYSQL(错误1053)无法正常启动

SEO最新算法