前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql分组函数

mysql分组函数

作者头像
用户7630333
发布2023-12-07 13:49:20
1590
发布2023-12-07 13:49:20
举报
文章被收录于专栏:look Java

分组函数:

  count            计数函数   计算某个字段出现的里面的内容 不为null 就+1

  sum(需要计算的那l列字段);·  求和函数

  avg()            求和函数

  max()            求字段中 最大值

  min()            求字段中 最小值

注意:

  1.所有的分组函数都是对“某一组”数据进行操作的。

  2.分组函数自动忽略NULL。

  3.SQL语句当中有一个语法规则,分组函数不可直接使用在where子句当中。why????

    怎么解释?         因为group by是在where执行之后才会执行的。

count(*)和count(具体的某个字段),他们有什么区别?   count(*):不是统计某个字段中数据的个数,而是统计总记录条数。(和某个字段无关)   count(comm): 表示统计comm字段中不为NULL的数据总数量。

分组函数也能组合起来用:   select count(*),sum(sal),avg(sal),max(sal),min(sal) from emp;

单行处理函数   什么是单行处理函数?     输入一行,输出一行。   计算每个员工的年薪?   select ename,(sal+comm)*12 as yearsal from emp;       重点:所有数据库都是这样规定的,只要有NULL参与的运算结果一定是NULL。     使用ifnull函数: 

    fnull() 空处理函数?       ifnull(可能为NULL的数据,被当做什么处理) : 属于单行处理函数。         select ename,ifnull(comm,0) as comm from emp;

group by 和 having   group by : 按照某个字段或者某些字段进行分组。   having : having是对分组之后的数据进行再次过滤。

注意:分组函数一般都会和group by联合使用,这也是为什么它被称为分组函数的原因。 并且任何一个分组函数(count sum avg max min)都是在group by语句执行结束之后才会执行的。 当一条sql语句没有group by的话,整张表的数据会自成一组。

select ename,max(sal),job from emp group by job; 以上在mysql当中,查询结果是有的,但是结果没有意义,在Oracle数据库当中会报错。语法错误。 Oracle的语法规则比MySQL语法规则严谨。 记住一个规则:当一条语句中有group by的话,select后面只能跟分组函数和参与分组的字段。

where后面不能使用分组函数: select deptno,avg(sal) from emp where avg(sal) > 2000 group by deptno; // 错误了。 这种情况只能使用having过滤。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-04-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档