SQL函数-聚合函数

聚合函数

聚合函数是对一组数据进行汇总输出的函数。

输入:一组数据集合
输出:单个值

举例:返回一组数据的最大值、平均数、最小、方差等操作。

常见函数举例:

1,AVG函数:返回一组数据的平均值
2,SUM函数:返回一组数据的总和
3,MAX、MIN函数:返回一组数据的最大、最小值
4,COUNT函数
COUNT(*) 返回表中记录的总数
COUNT(field)返回field字段不为空的记录总数
SELECT COUNT(telephone) FROM employees; # 返回employees表中telephone字段不为空的记录数
注:聚合函数不可嵌套使用, AVG(SUM(field))不可用

GROUP BY子句的使用:

使用GROUP BY子句,可以将表中数据分成若干组。需要和聚合函数group_function配合使用
举例:

点击查看代码

SELECT field1,group_function(field2)
FROM table
GROUP BY field1;  # 返回的结果中field1为一组,field2为一组

包含在GROUP BY子句中的 列/字段 也可以不包含在SELECT中,以下写法同样正确:
SELECT SUM(field2)
FROM table
GROUP BY field1;  # 以field1分组,计算field2字段的总和

输出示例:

SQL函数-聚合函数

使用多个字段分组:

点击查看代码

SELECT field1,field2,SUM(field3)
FROM table
GROUP BY filed1,filed2;

HAVING 子句:

用于过滤分组,不能单独使用,必须跟在GROUP BY后使用。

点击查看代码

SELECT field1,SUM(field2)
FROM table
GROUP BY field1
HAVING SUM(field2)>1000; # 返回SUM()大于1000的分组

非法使用聚合函数 : 不能在 WHERE 子句中使用聚合函数。

WHERE 和 HAVING 的区别:
1.WHERE可以直接使用表中的字段作为筛选条件,但不能使用分组中的计算函数作为筛选条件;HAVING 必须要与 GROUP BY 配合使用,可以把分组计算的函数和分组字段作为筛选条件。
2.如果需要通过连接从关联表中获取需要的数据,WHERE 是先筛选后连接,而 HAVING 是先连接后在结果集中筛选,执行效率低。

Original: https://www.cnblogs.com/iot502/p/16514750.html
Author: 康康在路上
Title: SQL函数-聚合函数

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/505156/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • django中的JsonRseponse对象

    json格式的数据 在进行前后端数据交互的时候,我们需要使用json格式的数据作为过渡,实现跨语言传输数据! django中的JsonResponse对象 在django中Json…

    数据库 2023年6月14日
    0116
  • JUC学习笔记(四)

    JUC学习笔记(一)https://www.cnblogs.com/lm66/p/15118407.htmlJUC学习笔记(二)https://www.cnblogs.com/lm…

    数据库 2023年6月6日
    0133
  • Python 垃圾回收总结

    前言 最近在阅读《垃圾回收的算法与实现》,里面将讲到了一些常用的垃圾回收(Garbage Collect)算法,如:标记-清除、引用计数、分代回收等等。后面讲到了 Python 的…

    数据库 2023年6月6日
    0155
  • 数据库原理四—MySQL日志

    重做日志redo log redo log是重做日志,为InnoDB存储引擎独有。它记录了数据页上的改动。当事务中修改了数据,将会备份存储。当发生数据库服务器宕机或者脏页未写入磁盘…

    数据库 2023年5月24日
    0155
  • Node安装与卸载命令汇总

    nvm(MAC管理node版本) 安装最新稳定版node: nvm install stable 安装指定版本: nvm install <version></v…

    数据库 2023年6月9日
    0118
  • [SWPU2019] Android3

    先反编译出java代码查看,发现没有坑,直接调用了库文件里的check 把so文件直接丢到ida中查找check函数,看到 这是说明flag是11位,刚好发现11个ascii码 &…

    数据库 2023年6月11日
    0137
  • 贪心算法原理及其应用

    概述 贪心算法应该算是那种”只闻其声不见其人”的算法,我们可能在好多地方都会听到贪心算法这一概念,并且它的算法思想也比较简单就是说算法只保证局部最优,进而达…

    数据库 2023年6月11日
    0186
  • LeetCode 9. 回文数

    题目 题目链接:https://leetcode.cn/problems/palindrome-number/ 给你一个整数x,如果x是一个回文整数,返回true;否则,返回fal…

    数据库 2023年6月11日
    0154
  • [javaweb]重点总结大全

    javaweb web:网页静态web:html,css 数据不会发生变化动态web:servlet/jsp,asp,php每个人在不同的时间看到数据都不同 web应用程序编写完毕…

    数据库 2023年6月16日
    0139
  • MYSQL–>SQL语法

    注:DDL(Data definition Language)数据库定义(比如说表,数据库)DML(Data Mainpulation Language)数据库 表的增删改查DQL…

    数据库 2023年6月14日
    0101
  • asp.net(C#)接MYSQL8.0版本报错的处理方法

    由于新的操作系统没有安装mysql,项目中需要使用到,于是安装了最新版本的mysql8.0.28(我安装的是社区版),如果你的项目是老项目,使用的mysql插件是比较老的版本,安装…

    数据库 2023年5月24日
    0245
  • chrome架构发展与提供的性能分析工具

    谷歌早期多进程架构分为插件进程(Plugin Process)、渲染进程(Render Process)、浏览器主进程(Browser Process) 插件进程负责插件的运行,通…

    数据库 2023年6月6日
    0364
  • pytest中pytest_cache文件夹作用

    跑自动化时经常会出现这样一个情况,一轮自动化跑完后零星出现了几个失败case,无法断定失败的原因,所以需要重新跑一下失败的case去debug,那我们要做的是就去修改脚本把那几个c…

    数据库 2023年6月11日
    0105
  • python中的cls和self区别

    self:Always use self for the first argument to instance methods self是作为类进行实例化传递的第一个参数,也就是我…

    数据库 2023年6月6日
    093
  • element-ui 提示框 确认按钮在左 取消按钮在右

    添加 //&#x53D6;&#x6D88;&#x6309;&#x94AE; &#x6837;&#x5F0F; cancelButto…

    数据库 2023年6月16日
    0126
  • Java 考试系统项目源码 springboot mybaits vue.js 支持手机端考试

    新增功能:培训学习模块, PDF电子课程、视频课程、直播课程(自己搭建直播流服务器) 人脸识别(考试时验证,有开关)、补考开关 组建试卷:创建试卷,题目、类型、总分、及格分数、时长…

    数据库 2023年6月6日
    0141
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球