1. 使用场景

很多时候我们需要查找数据库中符合特定条件的数据的计数、最大值、最小值、平均值等一个数字,并需要要导出所有相关数据明细。此时就需要用到聚集函数。

而返回所有数据明细会占用数据库资源和网络带宽资源。

聚集函数定义(aggregate function):运行在行组上,返回一个单一的值的函数。既,此类函数的运行对象都是行组数据,且只返回一个运算结果。

一个select语句中可以有多个聚集函数。

2. 常用聚集函数:

函数 说明
AVG() 返回某列的平均值
COUNT() 返回某列的行数
MAX() 返回某列的最大值
MIN() 返回某列的最小值
SUM() 返回某列的和

2. 1 avg() 通过计算某列的行数及所有行的值得和求得该列的平均值。

计算考试成绩的均值:

select avg(score) as avg_score
from test;

从test表中找到score这一列,计算并返回其平均值。

求出英语成绩的平均值:

select avg(score) as avg_score
from test
where major = 'English';

avg()函数后面可以通过where字句,只求出某列符合特定条件的行的平均值。

注意:

1. 单个avg()函数只能计算一列,想计算多列的平均值,只能使用多个avg()函数
2. avg()函数自己忽略值为null的行。

2.2 count() 计算整个表或某列的行数

count() 的两个使用方法:

1. count(*),计算某个表中的行数,不管是否有null值。

2. count(column), 根据某列有值的行计算行数。

#计算学生总数
select count(*) as num_students
from students;
# 有业余爱好的学生数
select count(hobby) as num_hobby
from students;

2.3 max() 返回某列最大值

常规可以用来检索的数据类型为数值和日期。如果文本数据按特定顺序排序,会返回最后一列。

# 找出考试中最高的数学成绩
select max(math) as max_math
from test;

2.4 min() 返回某列最小值

类似max()函数,常规可以用来检索的数据类型为数值和日期。如果文本数据按特定顺序排序,会返回最前一列。

# 找出百米冠军的用时
select min(100m_running) as min_time
from PE_testing;

2.5 sum() 返回某列之和

可以返回某列数值之和,也可返回某列特定条件的数值之和,还可返回结算列的和值。

# 全校捐款数
select sum(amount) as total_amount
from donation;
# 一年级总捐款数
select sum(amount) as total_amount_grade1
from donation
where grade = 1;
# 计算全校每周学生读书总计小时数
select sum(days*hours) as total_hour
from reading;

MySQL自学笔记_聚集函数的更多相关文章

  1. MySQL自学笔记_联结(join)

    1.  背景及原因 关系型数据库的一个基本原则是将不同细分数据放在单独的表中存储.这样做的好处是: 1).避免重复数据的出现 2).方便数据更新 3).避免创建重复数据时出错 例子: 有供应商信息和产 ...

  2. MySql学习笔记(三) —— 聚集函数的使用

    1.AVG() 求平均数 select avg(prod_price) as avg_price from products; --返回商品价格的平均值 ; --返回生产商id为1003的商品价格平均 ...

  3. jQuery源代码学习笔记_工具函数_noop/error/now/trim

    jQuery源代码学习笔记_工具函数_noop/error/now/trim jquery提供了一系列的工具函数,用于支持其运行,今天主要分析noop/error/now/trim这4个函数: 1.n ...

  4. Node.js自学笔记之回调函数

    写在前面:如果你是一个前端程序员,你不懂得像PHP.Python或Ruby等动态编程语言,然后你想创建自己的服务,那么Node.js是一个非常好的选择.这段时间对node.js进行了简单的学习,在这里 ...

  5. PostgreSQL自学笔记:6 PostgreSQL函数

    6 PostgreSQL函数 6.2 数学函数 abs(x) 绝对值 pi() 圆周率π select abs(-3),pi(); cookie: MySQL中的pi()默认值3.141593, Po ...

  6. Mysql自学笔记

    SQL(strucut query language) DDL (数据库定义语言)DML (数据库操作语言)DCL (数据库的控制语言)DTL (数据库的高级语言)查看版本的函数select vers ...

  7. mysql学习笔记—常用sql函数

    SQL 拥有很多可用于计数和计算的内建函数. SQL Aggregate 函数 SQL Aggregate 函数计算从列中取得的值,返回一个单一的值. 有用的 Aggregate 函数: AVG() ...

  8. MySQL学习笔记_时间,多表更新,数据库元数据

    MySQL技术内幕一.MySQL基础知识1.1.显示表中的列SHOW COLUMNS FROM order_info like 'order%'1.2.显示表SHOW TABLES LIKE 'ord ...

  9. MySQL 自学笔记_Union(组合查询)

    1. Union查询简介 组合查询:有时在使用select语句进行数据查询时,想要将多个select语句在一个查询结果中输出,此时就需要使用Union关键字. Union的使用方法:用union将多个 ...

随机推荐

  1. phpstorm使用

    生成注释快捷键/**+enter 注释快捷键ctrl+/

  2. Django中间件的执行流程

    Django中间件的执行流程. 请求到达中间件之后,先按照正序执行每个注册中间件的process_reques方法,process_request方法返回的值是None,就依次执行, 如果返回的值是H ...

  3. 微信小程序 笔记

    1.Input 输入控件 <input type='digit' placeholder='0.00'></input> 如果要使用单纯的数字控件,使那么可以将type设置为d ...

  4. [NWPU2016][寒假作业][正常版第三组]I

    素数环,简单的dfs,但这道题我有个小地方写错了半天发现不了..就是flag数组的位置.一定要放在if里面,刚开始没注意,一不小心写到外面了. #include <iostream> #i ...

  5. python之set集合、深浅拷贝

    一.基本数据类型补充 1,关于int和str在之前的学习中已经介绍了80%以上了,现在再补充一个字符串的基本操作: li = ['李嘉诚','何炅','海峰','刘嘉玲'] s = "_&q ...

  6. 安卓H5软键盘遮挡输入框

    由于安卓app内嵌入H5页面,webview对于软键盘没有处理(如果不是产品强烈要求建议不要处理这种拆东墙补西墙的问题,因为其他的手机上可能会出现已经优化软键盘的情况) 1.input下方还有多余空位 ...

  7. P3930 SAC E#1 - 一道大水题 Knight

    TLE,额 ,有空再写吧. #include<queue> #include<cstdio> #include<vector> #include<algori ...

  8. C#/.net基础知识

    1 .NET  中类和结构的区别? 答:结构和类具有大体的语法,但是结构受到的限制比类要多.结构不能申明有默认的构造函数,为结构的副本是又编译器创建 和销毁的,所以不需要默认的构造函数和析构函数.结构 ...

  9. vue-quill-editor上传内容由于图片是base64的导致字符太长的问题解决

    vue-quill-editor是个较为轻量级富文本框,相较于ueditor,开发更编辑,更加直观,如果大家伙在需求允许的情况下,还是会比较建议使用vue-quill-editor vue-quill ...

  10. TCP连接建立与关闭

    http://hi.baidu.com/psorqkxcsfbbghd/item/70f3bd91943b9248f14215cd TCP连接建立与关闭 TCP 是一个面向连接的协议,无论哪一方向另一 ...